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INTRODUCTION 


The Seagate ST225N, with its embedded controller, provides OEMs and system integrators with over 
21 megabytes of guaranteed formatted capacity in a shock-resistant half-height package. Seagate’s in- 
telligent drive with SCSI interface is a low-power full-function disc subsystem designed for single-user 
desktop systems. Whether in rugged industrial or quiet office environments, the space-saving ST225N 
provides a low-cost high-performance solution. 


High-reliability is assured through the use of LSI and surface-mount devices on a single printed circuit 
board. The ST225N uses fewer parts, cables and connectors for improved subsystem reliability. SCSI 
protocol is completely device independent and supports logical addressing, implied seeks, overlapped 
operations and multi-sector transfers up to 1.25 megabytes/second. Media defects and error recovery 
are efficiently managed within the device and fully transparent to the user. 


Our manufacturing facilities have been designed and located exclusively for high-volume production 
and testing of disc drives. Seagate’s ongoing commitment to vertical integration assures availability 
of the latest technology at the same consistent quality and lowest possible cost. Every stage of the 
production process is tightly controlled by highly refined procedures and staffed by skilled profession- 
als. Our proprietary final test and burn-in system continuously verifies our goals of volume produc- 
tion with rigorous quality control. 


Vil 


This document describes Seagate’s intelligent disc drive, designated ST225N. This Winchester disc drive 


includes an integrated controller which allows direct attachment to host systems which have SCSI- 
compatible adapters. 


ANSI X3T9.2/82-2 (Refer to Glossary, Appendix: 4) 


ST225N INTELLIGENT 
DISC DRIVE SPECIFICATIONS 3.0 


3.1 INTERFACE SUMMARY 


SCSI as defined by ANSI X3T9.2/82-2. The ST225N supports the SCSI extended command set for 
self-configuring software. 


e Disconnected Operations 

e Linked Commands 

e 1 Kbytes FIFO Buffer 

e Maximum Data Transfer Rate: 1.25 Mbytes/sec 

e Average Data Transfer Rate: 625 Kbytes/sec 

e Maximum Cable Length: 19.7 ft. (6 meters) 

e Provides Support for Arbitrating and Nonarbitrating Host Systems 


3.2 DRIVE CAPACITY AND PERFORMANCE 


3.2.1 FORMATTED CAPACITY 


Guaranteed Megabytes per Drive: 22.57 21.36 20.13 

Bytes per Cylinder: 36,864 34,816 37,768 
Bytes per Track: 9,216 8,704 8,192 
Bytes per Sector: 1,024 512 256 


3.2.2 DATA ORGANIZATION 


Guaranteed Sectors per Drive: 22,040 41,720 78,620 
Sectors per Cylinder: 36 68 128 
Sectors per Track: 9 17 32 


3.3 PERFORMANCE SPECIFICATIONS 


3.3.1 ACCESS TIME 


Track-to-Irack: 20msec 

Average: 65msec ' 
Maximum Seek: 15Omsec ' 
Latency: 8.33msec nominal 


1. Nominal power and temperature 


3.4 FUNCTIONAL SPECIFICATIONS 


Tracks: 2,460 

Cylinders: 615 _— 

Read/Write Heads: 4 

Discs: % 2 

Rotational Speed: . , 3,600 +.5% 
Recording Method: MFM 

Recording. Density: 9,827 BPI 

Flux Density: . 9,827 FCI 

Track Density: 588 TPI 

Interface: SCSI 

Data Command Rate: Up to 1.25 Megabytes/sec 
Nonrecoverable Read Errors: 1 per 10! bits read 


3.5 RELIABILITY SPECIFICATIONS 


MTBF: 20,000 Power-on Hours ” 
2 PM: Not Required 

MTTR: 30 minutes 

Component Design Life: 5 years 


3.6 ENVIRONMENTAL SPECIFICATIONS 


3.6.1 AMBIENT TEMPERATURE 


Operating: 10°C to 45°C (50°F to 113 °F) 
Nonoperating: : — -40°C to 60°C (-40° to 140°F) 


3.6.2 TEMPERATURE GRADIENT 
Operating: . 10 °C/hr max. ab: °F/hr) 


~Nonoperating: Below condensation 


3.6.3 RELATIVE HUMIDITY 


- Operating: 8 to 80% noncondensing 
Maximum Wet Bulb: 78.8 °F (26°C) noncondensing 
Nonoperating: Below. condensation 


3.6.4 ALTITUDE 


Operating: -1,000 ft to 10,000 ft 
Nonoperating: -1,000 ft to 30,000 ft 


3.6.5 OPERATING SHOCK 


Maximum permitted shock without incurring physical damage or degradation in performance: 
10 G’s** 


2. Typical usage at 25°C, at sea level. Calculated per Mil. Spec. handbook 217. 
3. 11msec half-sine wave shock pulse 


4. Input levels at drive mounting screws. Unit mounted in an approved orientation 
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3.6.6 OPERATING VIBRATION 


Maximum permitted vibration, at the following frequencies, without incurring physical damage or 
degradation in performance: ‘ 


Frequency Vibration 
5 — 22Hz .010” double amplitude 
22 — 300Hz .25 G peak amplitude 
300 — 22Hz .25 G peak amplitude 
22— 5Hz .010” double amplitude 


3.6.7 NONOPERATING SHOCK 


Maximum permitted shock without without incurring physical damage or degradation in performance: 
40 G’s *45 


3.6.8 NONOPERATING VIBRATION 


Maximum permitted vibration, at the following frequencies, without incurring physical damage or 
degradation in performance: *° 


Frequency Vibration 
5 — 22Hz .010” double amplitude 
22 — 300Hz .50 G peak amplitude 
300 — 22Hz .50 G peak amplitude 
22— 5Hz .010” double amplitude 


3.7 PHYSICAL SPECIFICATIONS 


Height: 1.63 inches max. (41.4mm) 
Width: | 5.75 “02 inches (146.05 *s) mm) 
Depth: 8.00 inches max. (203.2 mm) 
Weight: 2.75 Ibs. (1.25 Kg) 


3.8 DC POWER REQUIREMENTS 


Power may be applied or removed in any sequence without loss of data or damage to the drive 


+12VDC 

Voltage Tolerance (including ripple): +5% 

Maximum Current at Power-on: 2.2 Amps 

Average: .9 Amp 

+5VDC 

Voltage Tolerance (including ripple): +5% 

Maximum Current at Power-on 1.6 Amps 

Average: 1.2 Amps 

Power: | 16.8 Watts nominal with termination packs installed ° 


5. Heads positioned in the shipping zone © 


6. Measured under the following standard operating con .ticn:: 
1. 25°C ambient temperature 
2. Sea level 
3. Nominal voltages applied 
4. Spindle rotating with drive not seeking 


3.8.1 INPUT NOISE RIPPLE 


The maximum permitted input noise ripple is 100mV (peak-to-peak) on either +5VDC or +12VDC 
measured on the host system power supply across the following equivalent resistive loads: 


+12VDE: 16 0 
+5VDC: 50 


3.8.2 INPUT NOISE FREQUENCY 


The maximum permitted input noise frequency is 20MHz on both the +12VDC and +SVDC lines. 


Figure 1: lypical +12VDC Start-up Current Profile 
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3.9 MOUNTING REQUIREMENTS 
The ST225N may be mounted in the following orientations: 


Horizontal: Spindle Motor down 
Sides: Left or right 


The drive should not be tilted front to back, in any position, by more than +5°. 


Figure 2: Mounting Requirements 
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Dimensions are in inches (mm). 


NOTE: Mounting screws must not extend more 
than .25 inch inside frame. 


3.9.1 SHOCK MOUNTING RECOMMENDATIONS 


It is recommended that any external shock mounts between the drive and the host frame be designed 
so that the composite system has a vertical resonant frequency of 25Hz or lower. 


A minimum clearance of 0.050 inch should be allowed around the entire perimeter of the drive to 
allow for cooling airflow and mechanical vibration during shock or vibration. 


3.9.2 HANDLING AND STATIC DISCHARGE PRECAUTIONS 


After unpacking and prior to system integration, the drive is exposed to potential handling and ESD 
hazard. Observe standard static-discharge precautions and handle the drive by the frame only. 


Figure 3: Host/Drive Interface Connectors 
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3.10 I/O CABLE REQUIREMENTS 


3.10.1 CABLE 


A 50-conductor flat cable or 25-conductor twisted pair cable is required. The maximum cable length 
is 19.7 ft (6 meters). Each SCSI bus connection shall have a 0.1 meter maximum stub length. 


The characteristic impedance for unshielded flat or twisted pair ribbon cable should be 1009 +10%. 
A characteristic impedance greater than 900 is preferred for shielded cables. It is desireable to minimize 
the use of cables of different impedances in the same bus, so as to minimize discontinuities and signal 
reflections. Various implementations may require trade-offs in shielding effectiveness, cable length, 
the number of loads, transfer rates, and cost to achieve satisfactory system operation. 


3.10.2 BUS TERMINATION 


SCSI bus termination is provided within the device by removeable resistor termination pack. The ter- 
mination pack must be installed on the last drive on the interface cable. 


3.10.3 CONNECTOR REQUIREMENTS 


The drive connector is a 50-conductor connector consisting of two rows of 25 male pins on 100 mil 
centers. 


The cable connector is a 50-conductor nonshielded connector consisting of two rows of 25 female 
contacts on 100 mil centers. Recommended strain-relief connectors are AMP part number 1-499506-2 
or DUPONT part number 669002 (66900-250). 


Figure 4: Nonshielded Cable Connector 


Pm +.015 in (68.07 +.38 mm) 


strain Relief 


2.520 in. (64.01 mm) 


0.50 in. (1.27mm) 


iY i sn a © 


ruil Pl oes - 
ol fe 


Triangle Indicates a Ve 140 in. (3.55 mm) 
Position One 


2.680 +.015 in (68.07 +.38 mm) 
.100 in. (2.54 a “060 in. (1.52 mm) Polarizing Key 


pPze zd 
T 


x _ 100 in. (2.54 mm) = en in. (97 mm) 


Table 1: Connector Dimensions 


Editors Note: Please refer above to Figure 4 for nonshielded connector dimensions. 


Table 2: ST225N Connector Pin Assignments 
Note: All odd pins, except pin-25, must be connected to ground. Pin-25 should be left open, but may 
be connected to ground. | 


Signal | Pin Number 
-DB(0) | 2 
-DB(1) 4 
-DB(2) 6 
-DB(3) 8 
-DB(4) 10 
-DB() 12 
-DB(6) 14 
-DB(7) 16 
-DB(P) 18 
Ground 20 
Ground 22 
Ground 24 
Not Connected 26 
Ground 28 
Ground 30 
-ATN 32 
Ground 34 
-BSY 36 
-ACK 38 
-RST 40 
-MSG 42 
-SEL 44 
-C/D 46 
-REQ 48 


-I/O 50 


3.11 SCSI BUS DRIVERS/RECEIVERS 
The ST225N uses open collector drivers which meet the electrical requirements defined below. 


All signals are terminated with 2200 to +5VDC (nominal) and 3300 to ground. The terminating resis- 
tors are removeable for multi-drive configuration. 


Each signal driven by the ST225N has the following output characteristics, when measured at the drive 
connector: 


Signal assertion 0.0VDC to 0.4VDC 
Minimum driver output capability = 48mA (sinking) @ 0.5VDC 
Signal negation = 2.5VDC to 5.25VDC 


Each signal received by the ST225N must have the following input characteristics, when measured at 
the drive connector: 


Signal true: 0.0VDC to 0.8VDC 
Maximum total input load: -0.4mA @ 0.4VDC 
Signal false: 2.0VDC to 5.25VDC 
Minimum Input Hysteresis: 0.2VDC | 


Note: For these measurements, SCSI bus termination is assumed to be external to the drive. A typical 
ST225N is supplied with the resistor termination packs installed 
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GENERAL _ 


This section provides an overview of the product’s capabilities, configurations and interface charac- 
teristics. The ST225N disc drive has an integral SCSI-compatible controller. This embedded controller 
performs all of the functions that were previously implemented by an add-on, or “‘host supplied” con- 
troller. With the controller onboard, the diagnostic capabilities of the drive are enhanced because the 
controller is able to optimize drive performance and error recovery. 


4.1 INTERFACE 


The embedded controller supports the SCSI interface as defined in the ANSI X3T9.2 document. The. 
interface hardware is capable of transferring 1.2 Mbytes/second using asynchronous data transfer. Devices 
on the SCSI interface are daisy-chained together using a common cable. Both ends of the cable are 
terminated. All signals on the interface are common between all devices. The key elements of the inter- 
face are listed below. 


e SCSI interface compatible with ANSI standard 

e 1 Kbyte FIFO buffer 

e 1.25 Mbyte/sec data transfer rate (between controller and CPU) 
e Selectable SCSI Bus Address 

@ Supports extended SCSI command set 

e Supports disconnected operations 

e Supports linked commands 

e Extensive diagnostics and fault detection are provided 
e Operates with arbitrating and non-arbitrating hosts 

e Reports when error recovery was required 

e Supports 1:1 interleave factor 

e Reports error and usage information 


4.2 ERROR RECOVERY 


The controller provides error recovery routines which are necessary to assure data integrity. These tech- 
niques include ECC, seek-retry, read-retry, head-offset and defect management. To assure a high degree 
of data reliability, the controller utilizes a 32-bit error checking and correction polynomial. 


4.3 DISC FORMAT 


The disc format is flexible and supports sector sizes of 256, 512 and 1024 bytes per sector. 


4.4 FORMATTING AND DEFECT MANAGEMENT 


Media detects are identified and recorded on the disc during the manufacturing process. This defect 
map 1s used during formatting and enables the drive to bypass these defects. During the formatting 
operation, the controller uses the sector-slip technique to reassign defective sectors. A maximum of 
100 sectors can be slipped by the controller. This product supports the following three variations of 
the Format Command: 


@ Format using a combined list of previously defined defects (manufacturer’s list plus user-defined list) 
® Format with previously defined list plus additional user-defined defects 
® Format with manufacturer’s list only (removes al! user-defined defects) 


Refer to the Format Unit Command, Section 6.4, for further details. 


4.5 PERFORMANCE 


The onboard controller allows data to be transferred to/from the host at a maximum data transfer 
rate of 1.25 Mbytes/second. The data is then stored in a 1 Kbyte FIFO sector buffer. The controller 
supports a 1:1 interleave factor which allows the drive to be configured for maximum system | 
performance. 


Note: 1,024-byte/sector requires a 2:1 interleave 


4.6 DIAGNOSTICS 


The ST225N supports the following online diagnostics, which assure a high degree of data integrity. 
These routines are executed at power-on and verify the following controller and drive operations. 


¢ Controller 

e Read Operations 
e Data Buffer 

e Seek Operations 
e ECC 

e Spindle Speed 


In the event that a failure is detected during the power-on/initialization routines, the drive will indi- 
cate the failure type by flashing the LED. 


4.6.1 OFFLINE VERIFICATION PROGRAM 


The ST225N provides an offline hardware and error rate verification program. A jumper at the I/O 
interface will enable the program. Included are the following routines: 


1. Power-on hardware test 

2. Read/Write verification on special test cylinder 

3. Media scan of user data area | 

4. Seek Test 

The program will continue to cycle as long as power is applied or the tests execute successfully. The 


LED functions as a pass/fail indicator and will remain on as long as the drive is operating and pass- 
ing the verification routines. If the unit fails a test the test is terminated and the LED will be turned off. 


4.7 RECORD INTERLEAVE 
The ST225N supports user-specified record interleaves of 1:1 (records formatted sequentially on the 


disc) through the number of records per track minus one. This gives the user the ability to configure 
the drive for maximum performance within the operating environment. 


4.8 SCSI BUS ADDRESS 


Three jumpers are provided on the drive for selecting the SCSI bus address. The microprocessor ac- 
cesses this information at power-on and configures its operation accordingly. Refer to Figure 3 for 
address configuration details. 
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Note: The address jumpers are accessed only during the power-on sequence. If the SCSI address is 
changed, the drive must be powered off and on. 


4.9 DRIVE CONFIGURATION 


The ST225N supports four commands which determine and control the drive’s operating environment. 


Read Capacity: Defines the formatted capacity 

Inquiry: Defines the drive type and identifies physical device 
parameters 

Mode Sense: Defines the drive’s current operating environment 

Mode Select: Provides a method to change the operating characteristics 


of the drive 
The host system can control the following key parameters: 


e Total number of blocks available 
Block Length 
e Record interleave 


Enable/disable of error recovery 
e Enabling/disabling reporting of recovered error states 


Enabling/disabling of reporting usage and error counter overflow 


4.10 ERROR INFORMATION 


The ST225N has extensive error logging and reporting capability which enables the user to design general 
error recovery procedures within the operating system I/O drivers. 


Non device-specific error recovery procedures may be designed by using the SCSI Extended Sense capa- 
bility and the Sense Keys. The error information contained within the Extended Sense bytes is suffi- 
cient to manage defects and measure error rates thereby insuring a high degree of data integrity. To 
retrieve the Sense information, a Request Sense Command must be sent immediately following a reported 
error. 
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5.0 ______SCSI INTERFACE DESCRIPTION 


This is the physical path definition which is designed to provide an efficient method of communica- 
tion between computers and peripheral. devices, which includes the following features. 


e Single daisy-chained cable with up to eight connections 

e Asynchronous communications of up to 1.25 Mbytes/sec . 
© Up to 19.7 ft. (6 meter) cable length 

e Supports multiple overlaped disc drive operations 


5.1 SCSI BUS 


Communication on the SCSI bus is allowed between only two devices at any given time, with a maxi- 
mum of eight (8) devices (including the host). Each device has a SCSI ID bit assigned, as indicated 
below in Table 3. | 


When two devices communicate on the SCSI bus, the unit originating the operation is designated as 
the /nitiator and the unit performing the operation is designated as the 7arget. There may be any com- © 
bination of Initiators and Targets. 


Data transfers on the data bus are asynchronous and follow a defined REQ/ACK handshake protocol. 
One byte of information is transfered with each handshake. 


Table 3: SCSI ID Bits 
DB(7) DB(6) DB(5) DB(4) DB(3) 0B(2) DB(1) DB(0) — DATA BUS 
SCSI ID=0 
SCSI ID=1 
SCSI 1D=2 
SCSI ID=3 
SCSI ID=4 
SCSI ID=5 


SCSI ID=6 


SCSI ID=7 
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Figure 6: Sample SCSI Configurations 
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5.1.1 SCSI PHYSICAL PATH PHILOSOPHY 


Figure 6 illustrates a typical Initiator/Target command execution on the SCSI bus. This is only one 
of a number of possible partitions of the physical/functional interface. 


Figure 6: Physical Path 
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5.1.2 SCSI BUS SIGNALS 


There are nine control signals and nine data signals. 


lable 4: SCS/ Bus Signals 


Busy (BSY): An “‘or-tied” signal which indicates that the bus is in use. 


Select ( SEL): A signal used by an Initiator to select a Target or by a Target to 
reselect an Initiator. 


Control/Data (C/D): A signal driven by a Target. It indicates whether Control or 
Data information is on the data bus. True indicates Control. 


Input/Output (I/O): A signal driven by a Target which controls the direction of data 
flow on the data bus, with respect to an Initiator. True indicates 
input to the Initiator. 


_ Message (MSG): A signal driven by a Target during the message phase. 


Request (REQ): A signal driven by a Target to indicate a request for a REQ/ACK 
data transfer handshake. 


Acknowledge (ACK): A signal driven by an Initiator to indicate an acknowledgement 
for a REQ/ACK data transfer handshake. 


Attention (ATN): A signal driven by an Initiator to indicate the attention 
condition. 
Reset (RST): An “or-tied” signal which indicates the reset condition. 


5.1.2.1 SIGNAL VALUES 
Signals may assume either true or false values. There are two methods of driving these signals. In either 


case, the signal must be actively driven true. 


In the case of the “or-tied” drivers, the driver does not drive the signal to the false state, instead, the 
bias circuitry of the bus terminators pulls the signal false whenever it is “released” (not driven by the 
drivers. at every drive). 
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In the case of the “non or-tied”’ driver, the signal may be actively driven false or may be negated or 
simply released, in which case the bias circuitry will pull it false. 


5.1.2.2 ““OR-TIED’’ SIGNALS 


The BSY and RST signals are “or-tied?’ In the ordinary operation of the bus, these signals are simul- 
taneously driven true by several drivers. No other signals are simultaneously driven by two or more 
drivers. Any signal, other than BSY and RST, may employ “‘or-tied”’ or “non or-tied’’ drivers. There 
is no operational problem in mixing “‘or-tied” or “non or-tied” drivers on the same signal. 


5.1.2.3 SIGNAL SOURCES 


Table 5 indicates which type of device is allowed to source each signal. No attempt is made to show 
if this source is driving asserted, nonasserted or passive. All device drivers that are not active sources 
shall be in the passive state. Note that the RST signal may be sourced by any device. 


Table 5: Signal Sources 


C/D, I/O 

Bus Phase BSY SEL MSG,REQ ACK/ATN DB(7-0,P) 
Bus Free None None None None None 
Arbitration All Winner None None SCSI ID 
Selection I&T Initiator None Initiator Initiator 
Reselection I&T Target Target Initiator Target 
Command Target None Target Initiator Initiator 
Data In Target None Target Initiator Target 
Data Out Target None Target Initiator Initiator 
Status Target None Target Initiator Target 
Message In Target None Target Initiator Target 
Message Out Target None Target Initiator Initiator 
ALT: The signal shall be driven by all drives that are actively 

arbitrating. 
SCSI ID: A unique data bit (the SCSI ID) must be driven by each SCSI 


drive that is actively arbitrating. The other seven data bits must 
be released, i.e., not driven by this device. 


T&T: The signals are driven by the Initiator and/or Target as specified 
in the Arbitration and Selection phases. 


INITIATOR: If this signal is driven, it may only be driven by the active 
Initiator. 

NONE: This signal must be released, i.e, not driven by any SCSI device. 
The bias circuitry of the bus termninator pulls the signal to the 
false state. 

WINNER: This signal must be driven by the one drive that wins 
Arbitration. 

TARGET: If this signal is driven, it will be driven only by the active Target. 
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5.1.3 SCSI BUS TIMING 


Unless otherwise indicated, the delay time measurements for each drive shall be calculated from signal 
conditions existing at that drive’s own SCSI bus connection. Normally, these measurements need not 
consider delays in the cable. 


Arbitration Delay (2.2sec min., no max.): The minimum time that a device will wait from asserting 
BSY for arbitration until the data bus can be examined for an arbitration win. 


Assertion Period (90nsec min.): The minimum time that a Target will assert REQ while using syn- 
chronous data transfers. Also, the minimum time that an Initiator will assert ACK while using syn- 
chronous data transfers. 


Bus Clear Delay (800nsec max.): The maximum time for a device to stop driving all bus signals after: 


1. BUS FREE phase is detected (BSY and SEL both false for a Bus Settle Delay) 
2. Select is received from another drive during Arbitration phase. 


Note: For the first condition above, the maximum time for a device to clear the bus is 1200nsec. from 
BSY and SEL first becoming false. If a device requires more than a Bus Settle Delay to detect Bus 
Free, it shall clear the bus within a Bus Clear Delay minus the excess time. 


Bus Free Delay (400nsec min.}): The minimum time that a device will wait for its detection of the 
Bus Free phase (BSY and SEL both false for a Bus Settle Delay) until its assertion of BSY when going 
to the Arbitration phase. 

Bus Set Delay (1.8usec max.): The maximum time for a device to assert BSY and its SCSI ID bit on 
the data bus after it detects Bus Free phase (BSY and SEL both false for a Bus Settle Delay) for the 
purpose of entering Arbitration phase. 


Bus Settle Delay (400nsec): The time to wait for the bus to settle after changing certain control signals. 


Cable Skew Delay (10nsec max.): The maximum difference in propagation time allowed between any 
two SCSI bus signals when measured between any two devices. 


Data Release Delay (400nsec max.): The maximum time for an Initiator to release the data bus signals 
following the transition of the I/O signal from false to true. 


Deskew Delay ( 45nsec min.): The minimum time required for deskew of certain signals. 

Reset Hold Time (25sec min., no max.) : The minimum time for which RST is asserted. 
Selection Abort Time (200usec max.): The maximum time that a Target/Initiator will take from its 
most recent detection of SEL or reselect until asserting a BSY response. This timeout is required to 
ensure that a Target/Initiator does not assert BSY after a selection/reselection phase has been aborted. 
This is not the selection timeout period. 

Selection Timeout Delay (250msec min., recommended): The minimum time that an Initiator/Target 
should wait for a BSY response during the selection/reselection phase before starting the timeout 


procedure. 


+ Timing meets ANSI X3T.2, Rev. 10 
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5.2 LOGICAL CHARACTERISTICS 


5.2.1 SCSI BUS PHASES 
The SCSI architecture includes eight distinct phases: 


. Bus Free phase 
. Arbitration phase 
. Selection phase 
. Reselection phase 


nn k& BW Kho —_ 


. Command phase 
+6. Data phase 

17. Status phase 
18. Message phase 


+ These phases are collectively termed the information transfer phases. 


The SCS! bus can never be in more than one phase at any given time. Unless otherwise noted, signals 
that are not mentioned shail not be asserted. 


5.2.1.1 BUS FREE PHASE 


This phase indicates that no SCSI device is actively using the bus and that it is available for subsequent 
users. 


SCSI devices will detect the Bus Free phase after SEL and BSY are both false for at least a Bus Settle 
delay. 


SCSI devices must release all bus signals within a Bus Clear delay after BSY and SEL are continuously 
false for a Bus Settle delay. If a device requires more than a Bus Settle delay to detect the Bus Free 
phase, it must release all SCSI bus signals within a Bus Clear delay minus the excess time to detect 
the Bus Free phase. The total time to clear the bus must not exceed a Bus Settle delay plus a Bus Clear 
delay. 


5.2.1.2 ARBITRATION PHASE 


This phase allows one SCSI device to gain control of the bus so that it can assume the role of an 
Initiator or Target. The procedure by which a SCSI device gains control of the bus is as follows: 


1. The device must first wait for the Bus Free phase to occur. The Bus Free phase is detected whenever 
both BSY and SEL are simultaneously and continuously false for a minimum of a Bus Settle delay. 


2. The device must wait a minimum of a Bus Free delay after detection of the Bus Free phase (i.e., 
after BSY and SEL are both false for a Bus Settle delay) before driving any signal. 

3. Following the Bus Free delay in Step (2), the device may arbitrate for the SCSI Bus by asserting 
BSY and its own SCSI ID , however the device must not arbitrate (i.e., assert BSY and its SCSI 
ID) if more than a Bus Set delay has passed since the Bus Free phase was last observed. 

4. After waiting at least an Arbitration delay (measured from its assertion of BSY) the device must 
examine the data bus. If a higher priority SCSI ID bit is true on the data bus (DB 7 is the highest), 
then the device has lost the Arbitration and the device may release its signals and return to Step (1). 
If no higher priority SCSI ID bit is true on the data bus, the the device has won the Arbitration 
and it must assert SEL. Any other device that is participating in the Arbitration phase has lost 
the Arbitration and must release BSY and its SCSI ID bit within a BusClear delay after SEL becomes 
true. A device that loses Arbitration may return to Step (1). 
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5. The device that wins Arbitration must wait at least a Bus Clear delay plus a Bus Settle delay after 
asserting SEL, before changing any signals. 


Note: The SCSI ID bit is a single bit on the Data bus that corresponds to the device’s unique SCSI 
address. Ali other seven Data bus bits will be released by the device. 


5.2.1.3 SELECTION PHASE 


This phase allows an Initiator to select a Target for the purpose of initiating some Target function 
(e.g., Read or Write Command). During the Selection phase the I/O signal must be negated so that 
this phase can be distinguished from the Reselection phase. 


5.2.1.3.1 NONARBITRATING SYSTEMS tT 


In systems with the Arbitration phase not implemented, the Initiator must first detect the Bus Free 
phase and then wait a minimum of a Bus Clear delay. Then, except in certain single-Initiator environ- 
ments with Initiators employing the single Initiator option (refer to Section 5.2.1.3.4), the Initiator 
shall assert the desired Target’s SCSI ID and its own Initiator SCSI ID on the Data bus. After two 
Deskew delays the Initiator must assert SEL. 


5.2.1.3.2 ARBITRATING SYSTEMS fT 


The device that won Arbitration has both BSY and SEL asserted and has delayed at least a Bus Clear 
delay plus a Bus Settle delay before ending the Arbitration phase. The device that won the arbitration 
becomes an Initiator by releasing I/O. The Initiator will set the Data bus to a value which is the OR 
of its SCSI ID and the Target’s SCSI ID bit. The Initiator must then wait at least a Bus Settle delay 
before looking for a response from the Target. 


+ The ST225N is compatible with both arbitrating and nonarbitrating Initiators. 


5.2.1.3.3 ALL SYSTEMS 


In all systems, the Target must determine that it is selected when SEL and its SCSI ID bit are true 
and BSY and I/O are false for at least a Bus Settle delay. The Selected Target must then assert BSY 
within a Selection Abort time (of its most recent detection of being selected), which is required for 
correct operation of the timeout procedure. If more than two SCSI ID bits are on the Data bus, the 
Target will not respond to selection. | 


The Initiator will release SEL, and may change the Data bus, at least two Deskew delays after it detects 
that BSY is true. 


5.2.1.3.4 SINGLE INITIATOR 


Initiators that do not implement the Reselection phase and do not operate in the multiple-Initiator 
environment are alllowed to set only the Target’s SCSI ID bit during the Selection phase. This makes 
it impossible for the Target to determine the Initiator’s SCSI ID. 


5.2.1.3.5 SELECTION TIMEOUT PROCEDURE 


The recommended Selection Timeout procedure for clearing the SCSI Bus after the Initiator has waited 
a minimum of a Selection Timeout delay and there has been no BSY response from the Target is as 
follows. 


The Initiator will continue asserting SEL and will release the Data bus. If the Initiator has not detected 
BSY to be true after at least a Selection Abort time plus two Deskew delays, it will release SEL allow- 
ing the SCSI bus to go to the Bus Free phase. Devices must ensure that when responding to Selection, 
that selection was still valid within a Selection Abort time of their assertion of BSY. 
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Failure to comply with this requirement could result in an improper selection. For example, two Tar- 
gets connected to the same Initiator, the wrong Target connected to an Initiator or a Target connected 
to a nonexistent Initiator. 


5.2.1.4 RESELECTION PHASE 


Reselection allows the Target to reconnect to an Initiator for the purpose of continuing some opera- 
tion that was previously started by the Initiator, but was suspended by the Target, i.e., the Target dis- 
connected by allowing a Bus Free phase to occur before the operation was complete. Reselection can 
only be used in systems that have the Arbitration phase implemented. 


Upon completing the Arbitration phase, the winning device has both BSY and SEL asserted and has 
delayed at least a Bus Clear delay plus a Bus Settle delay. The winning device becomes a Target by 
asserting the I/O signal and setting the Data bus to a value that is the OR of its SCSI ID bit and 
the Initiator’s SCSI ID bit. The Target must wait at least a Bus Settle delay before looking for a response 
from the Initiator. 


The Initiator determines that it is selected when SEL, I/O and its SCSI ID bit are true and BSY is 
false for at least a Bus Settle delay. For correct operation of the timeout procedure; the reselected Initi- 
ator must assert BSY within a Selection Abort time of its detection of selection. If more than two 
SCSI ID bits are on the Data bus, the Initiator must not respond to a reselection. 


After the Target detects BSY, it must also assert BSY and wait at least two Deskew delays mand then 
release SEL. The Target may then change the I/O signal and the Data bus. The reselected Initiator 
will release BSY after it detects SEL false. The Target must continue asserting BSY until it is ready 
to relinquish the SCSI Bus. 


5.2.1.4.1 RESELECTION TIMEOUT PROCEDURE 


The Target will make a total of three attempts to reselect the Initiator. The following procedure is used 
to clear the SCSI bus after a reselection timeout. 


The Target will continue asserting SEL and I/O and will release all Data bus signals. If the Target 
has not detected BSY to be true for at least a Selection Abort time plus two Deskew delays, the Target 
will release SEL and I/O allowing the SCSI bus to go to the Bus Free phase. Devices that respond 
to Reselection must ensure that the Reselection was still valid within a Selection Abort time of their 
assertion of BSY. Failure to comply with this requirement could result in an improper reselection, Le., 
two Initiators connected to the same Target or the wrong Initiator connected to a Target. 


5.2.1.4.2 INFORMATION TRANSFER PHASES 


Command, Data and Message phases are all grouped together as the Information Transfer phases 
because they are all used to transfer data or control information via the Data bus. 


The C/D, I/O and MSG signals are used to distinguish between the different information transfer 
phases. The Target drives these three signals and therefore controls all changes from one phase to another. 
The Initiator can request a Message Out phase by asserting AI'N, while the Target can cause the Bus 
Free phase by releasing MSG, C/D, I/O and BSY. 
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Table 6: Information Transfer Phases 


SIGNAL 


Phase Name Direction of Transfer Comment 


DATA OUT Initiator to target 
DATA IN Initiator from target 
COMMAND Initiator to target 


STATUS Initiator from target 


* 


* 


MESSAGE OUT Initiator to target > Message 
MESSAGE IN Initiator from target Phase 


The Information Transfer phases use one or more REQ/ACK handshakes to control information transfer. 
Each REQ/ACK handshake allows the transfer of one byte of information. During the transfer BSY 
must remain true and SEL must remain false. Additionally, during the transfer, the Target must con- 
tinuously envelope the REQ/ACK handshake(s) with C/D, I/O and MSG in such a manner that these 
control signals are valid for a Bus Settle delay before the assertion of REQ of the first handshake, 
and remain valid until the negation of ACK at the end of the last handshake. 


5.2.1.4.3 ASYNCHRONOUS INFORMATION TRANSFER 


The Target controls the direction of information transfer by means of the I/O signal. When I/O is 
true, information is transferred from the Target to the Initiator. When I/O is false, information is trans- 
ferred from the Initiator to the Target. 


If I/O is true (transfer to the Initiator), the Target must first drive DB(7-0) to their desired values, 
delay at least one Deskew delay plus a Cable Skew delay, then assert REQ. DB(7-0) must remain valid 
until ACK is true at the Target. The Initiator reads (DB 7-0) after REQ is true and then signals its 
acceptance of the data by asserting ACK. When ACK becomes true at the Target, the Target may change 
or release (DB 7-0) and then negate REQ. After REQ is false the Initiator must then negate ACK. 
After ACK is false the Target may continue the transfer by driving (DB (7-0) and asserting REQ, as 
described above. 


If I/O is false (transfer to the Target) the Target requests information by asserting REQ. The Initiator 
then drives DB(7-0) to their desired values, delays at least one Deskew delay plus a Cable Skew delay 
and asserts ACK. The Initiator must continue to drive DB(7-0) until REQ is false. When ACK becomes 
true at the Target, the Target reads DB(7-0) and then negates REQ. When REQ becomes false at the 
Initiator, the Initiator may then change or release DB(7-0) and negate REQ. 


5.2.1.5 COMMAND PHASE 
The Command phase allows the Target to request command information from the Initiator. 


The Target must assert the C/D signal and negate the I/O and MSG signals during the REQ/ACK 
handshake(s) of this phase. 


5.2.1.5.1 DATA PHASE 


The term Data Phase encompasses both the Data In and Data Out phase. 
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5.2.1.5.2 DATA IN PHASE 
The Data In phase allows the Target to request that data be sent to the Initiator. 


5.2.1.5.3 DATA OUT PHASE 


The Data out phase allows the Target to request that data be sent from the Initiator to the Target. 


5.2.1.6 STATUS PHASE 


The Status phase allows the Target to request that status information be sent from the Target to the 
Initiator. 


The Target must assert C/D and I/O and negate the MSG signal during the REQ/ACK handshake 
of this phase. 


5.2.1.7 MESSAGE PHASE 


This refers to Message In/Out phase. The first byte transferred in either of these phases must be either 
a single-byte message or the first byte of a multiple-byte message. Multiple-byte messages must be wholly 
contained within a single message phase. 


ed 


5.2.1.7.1 MESSAGE IN PHASE 


This phase allows the Target to request that messages be sent to the Initiator. 


The Target must assert C/D and I/O and negate the MSG signal during the REQ/ACK handshake 
oi this phase. 


5.2.1.7.2 MESSAGE OUT PHASE 


This phase allows the Target to request that messages be sent from the Initiator to the Target. The 
Target may invoke this phase at its convenience in response to the Attention condition (refer to Section 
5.2.1) created by the Initiator. 


The Target must assert C/D and and negate I/O during the REQ/ACK handshake(s) of this phase. 
The Target shall handshake byte(s) in this phase until ATN goes false. 


5.2.1.8 SIGNAL RESTRICTIONS BETWEEN PHASES 


When the SCSI bus is between two information transfer phases, the following restrictions apply to 
the SCSI bus signals: | 


1. The BSY, SEL, REQ and ACK signals must not change. 


2. The C/D, I/O, MSG and Data bus signals may change. When switching the Data bus direction 
from out to in (Target to Initiator), the Target must delay driving the Data Bus by at least a Data 
Release delay plus a Bus Settle delay after asserting the I/O signal and the Initiator must release 
the Data bus no later than a Data Release delay after I/O signal goes true. When switching the 
Data bus direction from in to out (Initiator to Target), the Target must release the Data bus no 
later than a Deskew delay after negating the I/O signal. 


3. The ATN and RST signals may change as defined under the descriptions for the Attention and 
Reset conditions. 
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5.3 ATTENTION CONDITION 


The Attention condition allows the Initiator to inform a Target that the Initiator has a message ready. 
The Target may access this message by performing a Message Out phase. 


The Initiator creates the Attention condition by asserting ATN at any time, except during the Arbitra- 
tion or Bus Free phases. 


The Target may respond with the Message Out phase. 


The Initiator may negate the ATN signal at any time, but it must not negate the ATN signal while 
the ACK signal is asserted during a Message Out phase. Normally, the Initiator negates ATN while 
REQ is true and ACK is false during the last REQ/ACK handshake of the Message Out phase. 


5.3.1 RESET CONDITION 


The Reset signal immediately clears all SCSI devices from the bus and take precedence over all other 
conditions and phases. Any SCSI device may may invoke the Reset condition by asserting RST for 
a minimum of a Reset Hold time. During Reset, the state of all other SCSI bus signals, other than 
RST, ts not defined. 


5.3.1.1 “HARD RESET’ OPTION 
The ST225N supports the “hard”? RST option. Upon detection of a RST the drive will: 


1. Clear all uncompleted commands 
2. Release all SCSI device reservations 


3. Return to normal operating mode 


5.4 SCSI BUS PHASE SEQUENCES 


The order in which phases are used on the SCSI bus follows a prescribed sequence. The RST condition 
can abort any phase and, in all systems, is always followed by the Bus Free phase. Also, any other 
phase can be followed by the Bus Free phase. 


5.4.1 NONARBITRATING SYSTEMS 


In systems where the Arbitration phase is not implemented, the permitted sequences are as illustrated 
in Figure 7. The normal progression is from Bus Free phase to Selection, and from Selection to one 
or more of the information transfer phases (Command, Data, Status or Message). 


5.4.2 ARBITRATING SYSTEMS 


In systems that implement Arbitration, the permitted sequences are as illustrated in Figure 7. The nor- 
mal progression is from Bus Free phase to Arbitration, from Arbitration to Selection or Reselection, 
and from Selection or Reselection to one or more of the information transfer phases (Command, Data, 
Status or Message). 
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Figure 7: Phase Sequences With Arbitration 


COMMAND or 
DATA or 
STATUS or 
MESSAGE PHASE 


SELECTION 
PHASE 


BUS FREE 
PHASE 


RESET Condition 


Figure 8: Phase Sequences Without Arbitration 


SELECTION COMMAND or 


BUS FREE f ARBITRATION Or DATA or 
PHASE | PHASE RESLECT ION STATUS or 
, PHASE MESSAGE PHASE 


RESET Condition 


5.4.3 ALL SYSTEMS 


There are no restrictions on the sequences between information transfer phases. A phase type may 
even be followed by the same phase type. 


5.5 SCSI POINTERS 


SCSI architecture provides for two sets of three pointers within each Initiator. The pointers reside in 
the Initiator path control. The first set of pointers are known as the current (active) pointers. These 
pointers represent the state of the interface and point to the next command, data or status byte to 
be transferred between the Initiator’s memory and the Target. There is only one set of current pointers 
in each Initiator. The current pointers are used by the Target currently connected to the Initiator. 
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The second set of pointers are known as the saved pointers. There is one set of saved pointers for 
each command that is currently active (whether or not it is currently connected). The Saved Command 
pointer always points to the start of the Command Descriptor Block for the current command. The 
Saved Status pointer always points to the start of the status area for the current command. At the 
beginning of each command, the Saved Data pointer points to the start of the data area. It remains 
at this value until the Target sends a Save Data Pointer message to the Initiator. In response to this 
message, the Initiator stores the value of the current data pointer into the Saved Data Pointer. The 
Target may restore the current pointers to their saved values by sending a Restore Pointers message 
to the Initiator. The Initiator moves the saved value of each pointer into the corresponding current 
pointer. Whenever an SCSI device disconnects from the bus, only the saved pointer values are retained. 
The current pointer values are restored from the saved values upon the next reconnection. 


5.6 MESSAGE SPECIFICATIONS 


The message system allows communication between an Initiator and an ST225N for purposes of phys- 
ical path management. The following section defines messages supported by the ST225N. 


5.6.1 MESSAGE SYSTEM 


The ST225N supports the messages listed below in 7able 7. These messages support such special func- 
tions as disconnect/reconnect and command-linking. The Initiator indicates that it can support more 
than the Command Complete message by creating the Attention condition prior to the bus state of 
SEL asserted and BSY deasserted in the Selection phase. 


When the drive recognizes the Attention condition, it will request a message byte from the Initiator 
by executing a Message-Out information transfer. The outcoming Identify message indicates the dis- 
connect/reconnect functions are supported by the Initiator. 


The first message sent by the Initiator after the Selection phase must be the Identify message. This 
permits the establishment of the physical path for a particular logical unit specified by the Initiator. 
After the Reselection phase, the Target’s first message must be Identify. This allows the physical path 
to be reestablished for the Target’s specified logical unit number. Under some exceptional conditions, 
an Initiator may send the Abort message or the Bus Device Reset message instead of the Identify mes- 
sage, as the first message. Only one logical unit number may be identified for any one selection sequence. 
A second Identify message (with a new logical unit number) must not be issued before the SCSI Bus 
has been released (Bus Free phase). 


Whenever a physical path is established in an Initiator that can accomodate disconnection and recon- 
nection, the Initiator must ensure that the active pointers of the physical path are equal to the saved 
pointers for that particular logical unit number. An implied Restore Pointers operation occurs as a 
result of connect or reconnect. 


When the drive recognizes the Attention condition, it will request a message byte from the Initiator 
by executing a Message-Out information transfer. . 
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Table 7: Message Codes 


Code Type Description Direction 
00H S Command Complete In 
04H O Disconnect In 
OSH O Initiator Detected Error Out 
06H O Abort Out 
07H O Message Reject In Out 
08H O No Operation Out 
OAH O Linked Command Complete In 
OBH O Linked Cmd. Cmplt. (With Flag) In 
OCH O Bus Device Reset Out 
80H-FEH O Identify In Out 


5.6.2 MESSAGES 
Single-byte messages are listed below. 
COMMAND COMPLETE 009 (Required): Sent from a Target to an Initiator to indicate that the 


execution of a command, or series of linked-commands, has terminated and that valid status has been 
sent to the Initiator. After successfully sending this message, the Target shall go to the Bus Free phase. 


This command may have been executed successfully or unsuccessfully as indicated in the status. 


SAVE DATA POINTER 029 (Not used on the ST225): This message is sent from the Target to direct 
the Initiator to save a copy of the presently active data pointer for the currently attached LU. 


RESTORE POINTERS 03 (Not used on the ST225): This message is sent from a Target to direct 
the initiator to restore the most recently saved pointers (for the currently attached LU) to the active state. 


DISCONNECT 049: Sent from a Target to inform an Initiator that the present physical path is going 
to be broken (the Target will disconnect by releasing BSY), but that a later reconnect will be required 
in order to complete the current operation. 


ABORT 06: The message is sent from the Initiator to the Target to clear the present operation. All 
pending data and status for the issuing Initiator shall be cleared and the Target will got to the Bus 
Free phase. No status or ending message will be sent for the operation. 


MESSAGE REJECT 07: This message is sent from either the Initiator or Target to indicate that 
the last message received was inappropriate or has not been implemented. 


NO OPERATION 08: No operation. 


LINKED-COMMAND COMPLETE 0A RH: Sent from a Target to an Initiator to indicate that the exe- 
cution of a linked-command has completed and that status has been sent. 


LINKED-COMMAND COMPLETE (With Flag) OBy: Sent from a Target to an Initiator to indicate 
that the execution of a linked-command (with the Flag set) has completed and status has been sent. 


BUS DEVICE RESET 0Cqy: This message can be sent from an Initiator to direct a Target to reset 


all current commands. This message forces the ST225N to an initial state with no operations pending 
for any Initiator. Upon recognizing this message, the drive will go to the Bus Free phase. 
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IDENTIFY 809 To FFA (Optional): This message can be sent by either the Initiator or Target. It 
is used to establish the physical path connection between an Initiator and Target. When sent from 
a Target to an Initiator during reconnection, an implied Restore Pointers message must be performed 
by the Initiator prior to completion of this message. 

Bit-7: This bit is always set to distinguish this MDESSARe from the others. 


Bit-6: This bit is only set by the Initiator. When it is set, it indicates that the Initiator has the mo 
to accommodate disconnection and reconnection. 


Bits 5-3: Reserved. 


Bits 2-0: These bits specify a Logical Unit Number (LUN), and must be zero. 


5.7 COMPLETION STATUS 


Completion Status is sent from the Target to the Initiator at the termination of a command set. 


Table 8: ens Status 7 


BYTE : 
an RESERVED Status s Byte Code — 


Table 9: banca Status Byte Code Bit Values 


aa OF STATUS BYTE STATUS REPRESENTED 
a ee 


Good Status 


Check Condition 


Busy 


Intermediate Status/Good Status 


Reservation Conflict 


GOOD STATUS: This status indicates that the ST225N has sucessfully completed the command. 


CHECK CONDITION: Any error, exception or abnormal condition which causes sense information 
to be set, shall cause CHECK CONDITION status. The Request Sense Command should be issued 
following CHECK CONDITION status, to determine the nature of the condition. 
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BUSY: The ST225N is busy. This status will be sent whenever the ST225N is unable to accept a com- 
mand from an Initiator. 


INTERMEDIATE STATUS SENT: This status is sent for every command in a series of linked-commands 
(except for the last command), unless an error, exception or abnormal condition causes CHECK CON- 
DITION status to be sent. If this status is not sent, the chain of linked-commands is broken and no 
further commands in the series will be executed. 


RESERVATION CONFLICT: This status is returned whenever an SCSI device attempts to access a 
logical unit that is reserved to another SCSI device. 


5.8 SCSI COMMANDS 
This section defines the SCSI command structure and gives several examples. 


The command definitions assume a data structure which provides the appearance at the interface of 
a contiguous set of logical block of a fixed or explicitly defined data length. The SCSI device maps 
the physical characteristics of the attached peripheral devices to one of the several logical structures 
defined by the device type code. | 


A single command may transfer one or more logical blocks of data. Multiple commands may be linked 
if they are sent to the same logical unit. A Target may disconnect from the SCSI bus to allow activity 
by the other SCSI devices while it is being prepared to transfer data. 


Upon command completion (successful or unsuccessful), the Target returns a status byte to the Initia- 
tor. Since most error and exception conditions cannot be adequately described with a single status 
byte, one status code (Check Condition) indicates that additional information is available. The Initia- 
tor may issue a Request Sense command to retrieve this additional information. 


5.8.1 COMMAND IMPLEMENTATION REQUIREMENTS 


The first byte of any SCSI command must contain an operation code as defined in this manual. Three 
bits (bits 7-5) of the second byte of each SCSI command specify the logical unit if it is not specified 
using the Identify message. The last byte of all SCSI commands must contain a control byte as de- 
fined in Section 5.8.2.6. 


5.8.1.1 RESERVED 


Reserved bits, bytes, fields and code values are set aside for future standardization. A reserved bit, 
field or byte must be set to zero. A Target which receives a reserved bit, field or byte that is not zero, 
Or a reserved code value must terminate the command with a Check Condition status. If Extended 
Sense is implemented, the Sense key must be set to Illegal Request. 


5.8.2 COMMAND DESCRIPTOR BLOCK 


A request to a peripheral device is performed by sending a Command Descriptor Block to the Target. 
For several commands, the request is accompanied by a list of parameters sent during the Data-Out 
phase. 


The Command Descriptor Block always has an operation code as the first byte of the command, fol- 
lowed by a logical unit number, command parameters (if any) and a control byte. 


If there is an invalid parameter in the Command Descriptor Block of any command, the ST225N will 
terminate the command without altering the medium. 
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5.8.2.1 OPERATION CODE 


The operation code of the Command Descriptor Block has a group code field and a command code 
field. The three-bit group code field provides for eight groups of command codes. The five-bit com- 
mand code field provides for thirty-two command codes in each group for a total of 256 possible oper- 
ation codes. | 


The group code specifies one of the following groups: Group 0: six-byte commands (see 7able lI) Group 
1: ten-byte commands (see Table 12) Group 2: Reserved (not supported) Group 3: Reserved (not sup- 
ported) Group 4: Reserved (not supported) Group 5: twelve-byte commands (not supported) Group 
6: vendor-unique (not supported) Group 7: vendor-unique (not supported) 


Table 10: Operation Code 

ei EF 
ALS | eee | = = 
So Group Code Command Code . 


lable 11: lypical Command Descriptor Block For Six-Byte Commands 


‘a a emasaes aor ) . — — =SEECRANEG 
: | | Operation Code 
| Logical Unit Number | Logical Block Address (if required) (MSB) 


Logical Block Address (if required) (LSB) 
: Transfer Length (if required) 


Control Byte 
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Rinks 12. laa canes shasul Ld allaehn 


BYTE 
Operation Code 
Logical Unit Number RESERVED RelAdr 
Logical Block Address (if required) Ee) 
Souical: Block Address (if required) 


Boo eae ana Address (if required) 


Logical Block Address (if required) (LSB) 
RESERVED 
Transfer Length cal required) ore 


Transfer Length (if required) (LSB) 


Control Byte 


5.8.2.2 LOGICAL UNIT NUMBER (LUN) 
The LUN must be zero for the ST225N. 


5.8.2.3 LOGICAL BLOCK ADDRESSES 
The logical block address on logical units must begin with block zero and be contiguous up to the 


last logical block on that logical unit. 


Group 0 command descriptor blocks contain 21-bit logical addresses. Group 1 command descriptor 
blocks contain 32-bit logical block addresses. 


The logical block concept implies that the apater and Target have previously established the number 
of data bytes per logical block. 


5.8.2.4 RELATIVE ADDRESS BIT 
The Relative Address bit (RELADR) is not supported. 


5.8.2.5 TRANSFER LENGTH 


The transfer length specifies the amount of data to be transferred, usually the number of blocks. For 
several commands the transfer length indicates the requested number of bytes to be sent as defined 
in the command description. For these commands the transfer length field may be identified by a differ- 
ent name. 
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Commands that use one byte for transfer length allow up to 256 blocks of data to be transferrred 
by one command. A transfer length of 1 to 255 indicates the number of blocks that will be transferred. 
A value of zero indicates 256 blocks. 


Commands that use two bytes for transfer length allow up to 65,535 blocks of data to be transferred 
by one command. In this case, a transfer length of zero indicates that no data transfer will take place. — 
A value of 1 to 65,535 indicates the number of blocks that will be transferred. 


For several commands, more than two bytes are allocated for transfer length. Refer to the specific com- 
mand description for further information. 


The transfer length of the commands that are used to send a list of parameters to a Target is called 
the parameter list length. The parameter list length specifies the number of bytes sent during the Data- 
Out phase. 


The transfer length of the commands that are used to return Sense Data (e.g., Request Sense, Inquiry, 
Mode Sense, etc.) to an Initiator is called the allocation length. The allocation length specifies the 
number of bytes that an Initiator has allocated for returned data. The Target must terminate the Data- 
In phase when the allocation length bytes have been transferred or when all available sense data have 
been returned to the Initiator, which ever is less. 


5.8.2.6 CONTROL BYTE 


The control byte is the last byte of every command descriptor block. Table J3 describes a typical 
control byte. 


Table 13: srssidiee abl 


BIT 
BYTE | 


Last | “Vendor Unique RESERVED Flag Link 


DESCRIPTION 


7-6 Vendor Unique — Must be zero for ST225N 
5-2 RESERVED 


1 Flag bit - if the link bit is zero, then the flag bit will be set to 
zero. If the link bit is one, and if the command terminates success-— 
Fully, the Target will send LINKED COMMAND COMPLETE message if the 
flag bit is zero and will send LINKED COMMAND COMPLETE (WITH FLAG) 
message if the flag bit is one. Typically, this bit is used to cause 
an interrupt in the Initiator between linked commands. 


0 Link bit - This bit is set to one to indicate that the Initiator 
desires an automatic link to the next command upon successful comple- 
tion of the current command. If the link bit is one, Targets that 
implement linked commands(upon successful termination of the command) 
will return INTERMEDIATE status and will then’ send one of the two 
messages defined by the flag bit (above). 
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5.8.2 COMMAND EXAMPLES 


5.8.3.1 SINGLE COMMAND EXAMPLE 


A typical operation on the SCSI bus is likely to include a single Read command to a peripheral device. 
This operation is described in detail with a request from the Initiator. This example assumes that no 
linked commands, malfunctions or errors occur. 


The Initiator has active pointers and a set of stored pointers representing active disconnected SCSI 
devices (an Initiator without disconnect capability does not require stored pointers). The Initiator sets 
up the active pointers for the operation requested, arbitrates for the SCSI bus and selects the Target. 
Once this process is completed, the Target assumes control of the operation. : 


Using a Read command as an example; the Target receives the command from the Initiator, interprets 
and executes it. The Target, in this case, gets data from the peripheral device and sends it to the Initia- 
tor. To end the operation, the Target sends a Command Complete message to the Initiator. 


5.8.3.2 DISCONNECT EXAMPLE 


In the above single command example, the length of time necessary to obtain the data may require 
a time consuming physical seek. In order to improve the system throughput, the Target may disconnect 
from the Initiator, freeing the SCSI bus to allow other requests to be sent to other logical units. To 
do this, the Initiator needs to be reselectable and capable of restoring the pointers upon reselection. 
The Target needs to be capable of arbitrating for the SCSI bus and reselecting the Initiator. 


After the Target has received the Read command and has determined that there will be a delay, it dis- 
connects by releasing BSY. 


When the data are ready to be transferred, the target reconnects to the Initiator. As a result of this 
reconnection, the Initiator restores the pointers to their most recently saved values (which, in this case, 
are the initial values) and the Target continues, as in the single command example, to finish the opera- 
tion. The Initiator recognizes that the operation is complete when the Command Complete message 
is received. 


5.8.3.3 LINKED COMMAND EXAMPLE 


The ST225N will accept linked command blocks from the host. It will then execute this “chain” without 
further system intervention. 


When the Link bit is set the drive will request the next command block immediately upon presentation 
of the Command Complete message. Execution of linked commands is identical to commands issued 
separately, except that the drive will request the next command block without going through either 
Bus Free phase or the Selection phase. 


Upon completion of a linked command, a Linked Command Complete message is sent from the drive 
to the Initiator. The Initiator must then set up the internal pointers for the next command chain. 
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6.0 __ST225N SCSI COMMAND DESCRIPTIONS 


lable 14: Command Summary 
Operation Code Type Description 


00H O Test Unit Ready 
1H O Rezero Unit 

3H O Request Sense 
4H S/E Format Unit 

7H O Reassign Blocks 
8H S Read 

AH S Write 

BH O Seek 

1H V Read Usage Counter 
12H E Inquiry 

ISH O Mode Select 

16H O Reserve 

17H O Release 

1IAH O Mode Sense 

IBH O Start/Stop 

ICy O Receive Diganostic Results 
IDH O Send Diagnostic 
25H E Read Capacity 
28H E Read 

2AH E Write 

37H O Read Defect Data 


6.1 TEST UNIT READY COMMAND 
PERIPHERAL DEVICE TYPE: ALL 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 00H 


Table 15: Test Unit are Command 


: “BIT 
BBYTE_ 
: Operation Code 


RESERVED 


RESERVED 


RESERVED 
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The Test Unit Ready Command provides a means to check if the drive is ready. This is not a request 
for a self-test. If the drive is ready, the command is terminated with Good Status, and the sense key 
is set to No Sense. Sense keys are valid only if Extended Sense is requested. 


6.2 REZERO UNIT COMMAND 
PERIPHERAL DEVICE TYPE: ALL 
OPERATION CODE TYPE: STANDARD 
OPERATION CODE: 01H 


Table 16: Rezero Unit Command 


ch tates eaclaeectaidhekracchsestashnat ester’ a. 


BIT 
BYTE 


ce 
ee 
pees ee Pie | 
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The Rezero Unit Command requests that the Target set the drive to Track @. 


6.3 REQUEST SENSE COMMAND 
PERIPHERAL DEVICE TYPE: ALL 
OPERATION CODE TYPE: STANDARD 
OPERATION CODE: 03H 


The Request Sense Command requests that the Target transfer Sense data to the Initiator. Extended 
Sense is supported ‘and will be provided if the Allocation Length is set to 5 or greater. When the Allo- 
cation Length is set to a value of 0-4 bytes, then Nonextended Sense will be generated. 


The Sense data is valid for a Check Condition Status returned on the prior command. This sense data 
is preserved for the Initiator until retrieved by the Request Sense command, or until receipt of the 
next command from the Initiator. Sense shall be cleared upon receipt of any subsequent command 
to the drive from the Initiator receiving the Check Condition Status. 


The Allocation Length specifies the number of bytes that the Initiator has allocated for returned sense 
data. An Allocation Length of less than five indicates that four bytes of Sense data shall be trans- 
ferred. Any other value shall indicate the number of bytes shall be transferred. The ST225N will ter- 
minate the data-in phase when the Allocation Length bytes have been transferred or when all available 
Sense data has been transferred to the Initiator. 
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Table ° 17 aa see ane 


“Gresean: Code 
“Logical Unit Number RESERVED 


RESERVED 


RESERVED 


peeoeatron Length 


RESERVED Flag 


Maximum Sense length is 22 bytes for Extended Sense or 27 bytes when the Usage Counters are returned. 
The Check Condition Status shall be used only to report fatal errors for this command. For example: 


e The Target receives a non-zero reserved bit in the Command Descriptor Block. 
e An unrecovered parity error occurs on the data bus. 
e A Target malfunction prevents return of the sense data. 


Following a fatal error on a Request Sense Command, sense data may be invalid. Refer to Section 
7.0 for Error Codes and Sense Keys. | 


6.3.1 NONEXTENDED SENSE 


Nonextended Sense is provided for compatibility with systems that do not accept Extended Sense. 


Table 18: Nonextended Sense Data Format 


Error Code 


Logical Block Address (MSB)_ : 
EOot Eee Block Address 
| #] bei asias Block Address (LSB) 


The Address Valid (ADVALID) bit indicates that the Logical Block Address bytes contain valid infor- 
mation related to the error code. 


The error class specifies a class of errors from zero through two. The error class, together with the 
error code form a sense code, which is analogous to a particular sense key. 
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6.3.2 EXTENDED SENSE 


Error class seven specifies Extended Sense. Error Code zero specifies the Extended Sense data format. 
Error Codes 1 through Fy are reserved. 


Table 19: Extended Sense Data Format 
Ee AARARS EASES ES 


RESERVED | 


3 Logical Block Address (MSB) 
4 | Logical Block Address 
5 


Logical Block Address 


BIT 
BYTE 


Logical Block Address (LSB) 


Additional Sense Length 


Additional Sense Bytes 


RESERVED 


RESERVED 


RESERVED 


ll RESERVED 

12 Additional Sense Code 
13 RESERVED 

14 RESERVED 

15 RESERVED 

16 RESERVED 

17 RESERVED 

18 Cylinder (MSB) 

19 Cylinder (LSB) 


Head 


i) 
pu 


7 
© 


Sector 
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The Valid bit indicates that the information bytes specify the unsigned Logical Block Address associated 
with the Sense key. Sense keys are described in Section 7.0. 


The Additional Sense bytes contain the Error Class and Error Code which would have been presented 
for Nonextended Sense and the Physical Address which corresponds with the Logical Block Address. 
On Overflow of Usage Counter error, the additional bytes will contain the alternate Error Code and 
the nine Usage Counter bytes for an Additional Sense Length of nineteen. 


Additional sense Byes For Usage Counters 


Blocks Read (MSB) 


Blocks Read (MSB) 
Blocks Read (LSB) 
Seeks (MSB) 
Sucké (MSB) 
Seeks (LSB) 
Uncorrectable Read Errors 


Correctable Read Errors 


Seek Errors 


6.4 FORMAT UNIT COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: STANDARD 
OPERATION CODE: 04H 


Table ~ iia =e ceciainiclll 


Ber Code 


Logical are Number Fmt Data} CmpLst Defect mae Format 
VENDOR UNIQUE 


Interleave (MSB) 


Interleave (LSB) 


RESERVED 
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The Format Command will write from Index to Index all ID and data fields with the format specified 
by a previous Mode Select Command. If no Mode Select Command has been executed, the previous 
format will be used. On unformatted discs, the default format of 512-byte sectors and a 1:1 interleave 
will be used. The ST225N provides a manufacturer’s defect list written on the drive that is used during 
the format operation to bypass defects which were identified during the manufacturing process. Addi- 
tional defects may be added to the manufacturer’s defect list. These defects are supplied as data to 
the Format Command. The Interleave Field requests that the logical blocks be related in a specific 
fashion to the physical blocks to facilitate speed matching. An interleave value of zero requests that 
the Target use its default interleave (1:1). An interleave value of one requests that consecutive logical 
blocks be placed in physical consecutive order. 


All valid interleave values, including 1:1 are supported by this product. Valid interleave values are from 
0 to sectors/track minus 1, i.e, for 17 sectors/track, the valid interleave values are from 0 to 16. 


Three format modes are supported by the ST225N. 


¢ Format with known defect list (original manfacturer’s defect list plus any previously supplied additions) 
e Format with known defect list plus supplied defects in Logical Block Format 


e Format with original manufacturer’s defect list only (remove any previously supplied additions) 


The Format Data (FMTDATA) bit, if one, indicates that format data is supplied during the data-out 
phase. The defect list included with this data specfies the defects which are to be entered onto the 
defect map. The FMTDATA bit, if zero, indicates that the data-out phase will not occur and no defect 
data will be supplied by the Initiator. 


The Complete List (CMPLST) bit, if one, indicates use only original manufacturers list. 


The CMPLST Bit, if zero, indicates the data supplied is in addition to existing defect data using the 
current format. 


Note: When the physical block size is changed, no attempt will be made to map defects supplied in 
Logical Block format to a new record size. Any supplied defect list is assumed to be for the requested 
block size. If an interleave value is changed and new defects are added, then the previous interleave 
value will be used to physically locate defects. 


Table 21: Format Command Variations 


BIT REFERENCE 


Format 


Data 
Complete 


Defect List Command Type Comments 


Format with known defect list. 
Standard No defect data sent from Initiator 
to Target. 


Format adding defects specified in 
Extended defect list to known defects. See 
Defect List Table (Block Format). 


Format using manufacturers defect 
Optional list only. 
Defect list length must be set to 
zero. 7 


oh, 


nie ea eee List—Block Format 


RESERVED 


RESERVED 


Defect List widcok (MSB ) 
Defect List ies teo aud 


Defect Descriptors 


Defect Block Address (MSB) 


Defect Block Address 


Defect Block Address 


Defect Block Address (058) 


The Defect List contains a four-byte header followed by one or more Defect Descriptors. The length 
of the Defect Descriptor is four bytes. The Defect List length specifies the length in bytes of the Defect 
Descriptors that follow. The Defect List length is equal to four times the number of Defect Descriptors. 


The Defect Descriptor for the block format specifies a four-byte defect block address which contains 
the defect. The Defect Descriptors must be in ascending order. | 


6.5 REASSIGN BLOCKS COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 07H 


This command requests that the Target reassign the defective Logical Blocks to an area on the drive 
reserved for this purpose. 


The Initiator transfers a defect list that contains the Logical Block Addresses to be reassigned. The 
Target will reassign the physical medium used for each Logical Block address in the list. The data con- 
tained in the logical blocks specified in the defect list will be lost. 


If the drive has insufficient capacity to reassign all of the defective logical blocks, the command will 
terminate with a CHECK CONDITION status and the Sense key shall be set to Medium Error. The 
logical block address of the last Logical Block reassigned will be returned in the information bytes 
of the Sense data. 


The Reassign Blocks defect list contains a four-byte header followed by one or more defect descrip- 
tors. The length of each Defect Descriptor is four bytes. 
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Table 23: Reassign Blocks Command 


Operation Code 


Logical Unit Number RESERVED 
RESERVED 
RESERVED 


RESERVED 


The Defect List length specifies the total length in bytes of the Defect Descriptors that follow. The 
Defect List length is equal to four times the number of Defect Descriptors. 


Blocks that have been reassigned by this command will be added to the “Known Defect List?’ These 


defective sectors will then be spared by the normal defect management method by the next Format 
Command. 


Table 24: slaci Blocks Defect List 


BYTE Defect List Header 


RESERVED 
RESERVED 


Defect List Length =) | 
Defect List oe anise 


Defect Descriptors 


Defect Logical Block Address (MSB) 
Defect Logical Block Address | 


Defect Logical Block Address | 
Defect ee Block Address (LSB) 


The Defect Descriptor specifies a four-byte defect Logical Block Address that contains the defect. The 
Defect Descriptors must be in ascending order. 
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6.6 READ COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: STANDARD 
OPERATION CODE: 08H 


Table 25: Reet Pannen 


BYTE 


Operation Code 
1 Logical Unit Number Logical Block Address Oe! 


Logical pooek Address 


“Logical Block Address (LSB) 


Transfer Length 


pee 


The Read Command requests that the Target transfer data to the Initiator. The Logical Block Address 
specifies the logical block where the Read operation shall begin. 


The Transfer Length specifies the number of contiguous logical blocks of data to be transferred. A 
Transfer Length of zero indicates 256 logical blocks shall be transterred. Any other value indicates 
the number of blocks to be transferred. | 


6.7 WRITE COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: STANDARD 
OPERATION CODE: 0AH 


The Write Command requests that the Target write the data transferred by the Initiator to the medium. 
The Logical Block Address specifies the logical block where the Write operation shall begin. 
The Transfer Length specifies the number of contiguous logical blocks of data to be transferred. A 


Transfer Length of zero indicates 256 logical blocks shall be transferred. Any other value indicates 
that number of logical blocks shall be transferred. 
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Table 26: Write Command 


BYTE 
Operation Code 
Logical Unit Number Logical Block Address (MSB) 


Logical Block Address 


Logical Block Address (LSB) 


Transfer Length 


RESERVED Flag Link 


6.8 SEEK COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: OBH 


Table 27: Seek Command 


Operation Code 


Logical Unit Number peace Block Address (MSB) 


Logical Block Address 


Logical Block Address (LSB) 


RESERVED 


ese Link 


This command requests that the drive seek to the specified Logical Block Address. 
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6.9 READ USAGE COUNTERS COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 114 


ee Be eee i Uign Gaunt celaledaall 


BYTE 


RESERVED 


RESERVED 


The Read Usage Counters Command is provided for tracking the number of blocks read, the number 
of seeks requiring carriage motion, the number of correctable/uncorrectable Read errors and the number 
of seek errors. Execution of this command will set the usage counters to zero. 


Note: The counter information is stored in RAM and may be lost when power is removed. 
When the usage or error counters overflow, an error will be generated on the next command, indicat- 
ing to the host that this has occured and the counters will be contained in the Sense information. After 


the sense information has been retrieved, the usage counters will be reset. 


The Mode Select Command is used to enable or disable the counter overflow error. the default is set 
SO error generation is disabled (see Mode Select). 7 
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Table 29: _— Counter Format 


a 
2 ae ar 
ch DOGO 
ee 
xz 


Uncorrectable Read Errors 


Correctable Read Errors 
[eee C—~* 


6.10 INQUIRY COMMAND 
PERIPHERAL DEVICE TYPE: ALL 
OPERATION CODE TYPE: EXTENDED 
OPERATION CODE: 12} 


Table 30: sa Command 


BIT 
BYTE | | 


ppevetiGa Code 
1 | Logical Unit Number RESERVED 
RESERVED 


RESERVED 


Allocation Length 


RESERVED Flag Link 


The Inquiry Command requests that information regarding parameters of the Target be sent to the 
Initiator. 
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The Allocation Length specifies the number of bytes that the Initiator has returned for Sense data. 
An Allocation Length of zero indicates that no inquiry data shall be transferred. This is not considered 
an error condition. Any other value will indicate that number number of bytes to be transferred. The 
Target will terminate the data-in phase when Allocation Length bytes have been transferred or, when 
all available Inquiry data has been transferred to the Initiator. 


The CHECK CONDITION status is reported when the Target cannot return the Inquiry data. 


Table 31: Inquiry Data 


The Inquiry data contains a five-byte header, followed by additional parameters, if any. 


BIT 
a | BYTE 


Device ane Code (00) 
- RMB (0) | Device Type Qualifier (00) 
Revision Level (01) 


Response Type SRD (00) 


Additional Length (39) 


Additional | Bytes | we | 


— 
RESERVED 
RESERVED 
SEAGATE (ascii) 
1 16-31 | ST225N (ascii) 


Hardware Revision Level 


ROM Revision Level 


Firmware Revision Level 
RESERVED 


Wl eC eo | | 
WoL Nd e | ™ ae. 
Wi . 
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Vendor-Unique Parameters 


DRIVE SERIAL NUMBER (MSB) | 


DRIVE SERIAL NUMBER 


36 | 

: 
» 
; 
: 
: 
ee 


The Removable Medium (RMB) bit is set to zero, indicating the medium is not removable. 

The Device Type Qualifier is a seven-bit user specified code. This code may be set using the Mode 
Select Command. The default value is 0. The Revision Level is the implemented revision level of this 
standard and is defined as follows: 


00H Revision Level is unspecified 


01H First release. This should be used for disc drives that claim to comply with 
the ANSI standard. 


02H-FFH Reserved 


The Additional Length specifies the length in bytes of additional drive parameters. 


6.11 MODE SELECT COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 151 


The Mode Select Command provides a means for the Initiator to specify or change operating parameters 
within the drive. 


The parameter list length specifies the number of bytes of Mode Select data to be transferred during 
the Data-Out Phase. A parameter list length of zero indicates that no data is transferred. 


The Mode Select parameter list contains a four-byte header followed by the block descriptor (if any), 
followed by zero or more page descriptors. 
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Table 32: Mode Select Command 


pest atten Code 


Logical Unit Number RESERVED 
RESERVED 
RESERVED 


Parameter List Length 


RESERVED 


RESERVED 
Medium Type (00) 
RESERVED 


Block Descriptor Length (8) 


Density Code (00) 
Number of Blocks (MSB) 


Number of Blocks 


Number of Blocks (LSB) 
RESERVED 


Block Eengen (MSB) 


Block Bengt” 


Block Length ( — 
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keto eee 


Page Length (bytes) 


Refer to page definition 


Refer to page definition 


Each page descriptor supplies information regarding a particular class of functions. The page descrip- 
tors may be in any order and do not have to be supplied. 


The SDP bit requests that the ST225N set the default parameters for this page. No page bytes need 
be sent when selecting default parameters. 


The page length indicates the number of bytes to be associated with this page and may be zero. 


Page Code 


Page Code = OOh 


Page Length (02h) 


| Recovery; Status RESERVED 
Device Type Qualifier 


Only one set of Mode Select parameters is kept for each drive. 


Operating parameters format: Page Code Oy. 


Table 34: Page Codes 


OH Operating Parameters 

1H Error Recovery Parameters 

2H Disconnection Parameters (default only) 
3H Format Parameters (default only) 

4H Geometry Parameters (default only) 

5H through 3FW Reserved (ignored) 


Usage specifies that upon overflow of the usage counters, an error be generated on the following com- 
mand and that the usage counter data be saved in the sense information. Default (0) disables error 
presentation upon the overflow condition. 


RECOV specifies that the ST225N report all errors without attempting error recovery, correction or 
retry operations. Default (0) enables all normal error recovery operations. 
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Status specifies that recovered error sense be reported in the event of a recoverable error, either by 
retry or correction. Default (0) disables recovered error sense. This bit is not applicable if retries are 
disabled by RECOV. 

The device type qualifier may be set to further identify a device. 

Page Code 01—Error Recovery parameters: This page is ignored—reported as all zeros. 

Page Code 01—Disconnection parameters: This page is ignored—reported as all zeros. 


Page Code 03—Format parameters: (sense only) 


Page Code 04—Geometry parameters: (sense only) 


Table 35: Direct Access Device Format Parameters 


sit 
B BYTE 


Page Code See st 


i 


Page Length (in yee 

Tmocine oF verecrs FIED 
7 — seep — ee 

RESERVED - 

RESERVED 

RESERVED —_ 


RESERVED 


RESERVED 


RESERVED 


RESERVED 


TRACK FORMAT FIELD = 


Sectors per Track (MSB) 


pe | oO 


Sectors per Track (LSB) 
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NO 
© 


NO NO 


NO 
WW 


NO 


WN 


= 


ON 


© 


_ 


. — peo! mem |e | p=  &- 


RESERVED 
RESERVED 


DRIVE TYPE FIELD 


RESERVED 


RESERVED 


SECTOR FORMAT FIELDS _ 
Bytes per Physical Sector (MSB) 
Bytes per Physical Sector (LSB) 

Interleave (MSB) 

Interleave (LSB) 
RESERVED 
RESERVED 


RESERVED 


RESERVED 


Sectors per Track: This indicates the number of physical sectors per disc track. 
Bytes per Physical Sector: This indicates the nubmer of bytes per physical sector. 


Interleave: This is the same parameter passed in the Format Unit Command and is only returned by 
the Mode Select Command. 
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Table S6:Di80 eons | y Parameters inal Code 4 os a 


BIT 
_BYTE 


be fe 
N | 


pb 
WN 


b=! ; 


a 
bo 


ae Gods - 4 


Page Length (in bytes) 


Number of Cylinders (MSB) 


_ Number of Cylinders 


Number of Cylinders (LSB) 


Number of Heads 


RESERVED 
RESERVED 


RESERVED 


RESERVED 


RESERVED 
RESERVED 
RESERVED 


RESERVED 


pee ee 


RESERVED 


RESERVED 
RESERVED 


6.12 RESERVE COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS, WRITE-ONCE 
READ-MULTIPLE, READ-ONLY DIRECT ACCESS 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 16 


Table 37: Reserve Command 
la i a ae 4 | 3 2 1 7 
BYTE | 
0 | Operation Code | 


ve Logical Unit Number | 3rd pty Third Party Device ID a 
=a Reservation Identification | 


RESERVED 


RESERVED 


The Reserve command is used to reserve the logical unit. A third-party reservation option is implemented, 
allowing logical units to be reserved for another specified SCSI device. The Reserve and Release Com- 
mands provide the basic mechanism for contention resolution in multiple-Initiator systems. 


This command requests that the entire logical unit be reserved for the exclusive use of the Initiator 
until released by a Release command from the same Initiator or by a Bus Device Reset message from 
any Initiator. A logical unit reservation will not be granted if the logical unit is reserved by another 
Initiator. It is permissible for an Initiator to reserve a logical unit that is currently reserved by that 
Initiator. 


If the unit is reserved for another Initiator, the Target will respond with Reservation Conflict Status. 


If, after honoring the reservation, any other Initiator subsequently attempts to perform any command 
on the reserved logical unit, other than a Release command, (which is ignored), the command will 
be rejected with a Reservation Conflict Status. 


6.12.1 THIRD-PARTY RESERVATION 


The third-party reservation option for the Reserve command allows an Initiator to reserve a logical 
unit for another SCSI device. This option is intended for use in multiple-Initiator systems that use 
the Copy command. 


If the third-party (3rdPTY) bit is zero, then the third-party reservation option is not requested. If the 
3rdPTY bit is one, then the Reserve command will reserve the specified logical unit for the SCSI device 
specified in the third-party device ID field. The Target will preserve the reservation until it is superceded 
by another valid Reserve command from the same Initiator or until it is released by the same Initiator, 
by a Bus Device Reset message from any Initiator, or a “hard” Reset condition. The Target will ignore 
any attempt to release the reservation made by any other Initiator. | 
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6.12.2 SUPERCEDING RESERVATIONS 


An Initiator that holds a current reservation may modify that reservation by issuing another Reserve 
command. The superceding Reserve command will release the previous reservation state when the new 
reservation is granted. 


Superceding reservations are principally intended to allow the SCSI device ID to be changed on a reser- 
vation using the third-party reservation option. This capability is necessary for certain situations when 
using the Copy command. 


6.13 RELEASE COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS, WRITE-ONCE 
READ-MULTIPLE, READ-ONLY DIRECT ACCESS 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 17H 


Table 38: Release Command 


Reservation Identification 


RESERVED 


RESERVED 


The Release command is used to release previously reserved logical units. It is not an error for an 
Initiator to attempt to release a reservation that is not currently active. 


6.13.1 THIRD-PARTY RELEASE 


The third-party release option for the Release command allows an Initiator to release a logical unit 
that was previously reserved using the third-party reservation option. This option is intended for use 
in multiple-Initiator systems that use the Copy command. If the third-party bit (3rdPTY) bit is zero, 
then the third-party release option is not requested. If the 3rdPTY bit is one, then the Target will release 
the specified logical unit, but only if the reservation was made by the same Initiator (using the third- 
party reservation option) for the same SCSI device as specified in the third-party device ID field. 


54 


6.14 MODE SENSE COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 1AH 


Table 39: Mode Sense Command 


BIT 
BYTE 


Operation Code 


Logical Unit Number RESERVED 


= 
RESERVED Page Code 
RESERVED 


Allocation Length 


~ The Mode Sense Command provides a means for a Target to report its medium, drive, or peripheral 
device parameters. It is a complementary command to the Mode Select Command. 


The Allocation Length specifies the number of bytes that the Initiator has allocated for returned Sense 
data. An Allocation Length of zero indicates no sense data will be transferred. This is not considered 
an error condition. Any other value indicates the number of bytes to be transferred. The Target will 
terminate the data-in phase when Allocation Length bytes have been transferred or when all available 
Sense data has been transferred to the Initiator. 


Mode Sense Header 


BIT | 7 5 4 ‘3 | 1 | 
BYTE | | | 


Sense Data Length (TBD) 


Medium Type (00) 


RESERVED 


Block Descriptor Length 


The Mode Sense data contains a four-byte header, followed by zero or more eight-byte Block Descrip- 
tors, followed by the additional drive parameters, if any. 
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Block era 


Density Code (00) 


Number of Blocks (MSB) 


Number of Blocks 
Number of Blocks co 
RESERVED 


BTOeK Length (MSB) 
Block beled 


Block a (L58) 


— Descriptors 


rage Code 
Page Length (bytes) 
Refer to ime definition 


distil to oe iatehatane 


Table 40: Page Codes 


44H, through 3Cy 
3DH 


3DH 


dFyW 


Operating Parameters (selectable) 

Error Recovery Parameters (default only) 

Disconnection Parameters (default only) 

Format Parameters (default only) 

Reserved (ignored) 

Report Default Values: All pages are returned with fields and bits set 
to their default values. 

Report Changeable Values: The operating parameters page is returned 
with all changeable bits set. 

Report Current Values: All pages are returned with their currently 
selected or default values. 


Refer to Mode Select for a list of all page data. 
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6.15 START/STOP COMMAND 
PERIPHERAL DEVICE TYPE: ALL 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 1BH 


Table 41: Start/Stop Command 


1 BYTE | | 


a 
ee ed 
ee 


The Start/Stop Command requests the ST225N to move the R/W heads to/from the shipping zone. 
An Immediate (IMMED) bit of one indicates that status shall be returned as soon as the operation 
is initiated. An IMMED bit of zero indicates that status shall be presented when the operation is com- 
pleted. A Start bit of one requests that the drive position itself at Track G. A Start bit of zero requests 
that the drive position itself at the shipping zone. 


6.16 RECEIVE DIAGNOSTIC RESULTS COMMAND 
PERIPHERAL DEVICE TYPE: ALL 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 1CH 


The Receive Diagnostic Results Command requests that analysis data be sent to the Initiator after 
completion of a Send Diagnostic Command. 


User Diagnostic Commands: Four bytes of Result data, conforming to the Nonextended Sense for- 


mat, will be returned regardless of the Allocation Length. The diagnostic data returned depends on 
the Diagnostic Command. | 


me 


Table 4 42: Receive ve Diat a | Resuits C Command — 


BE BIT 
BYTE 


Gnceatiens Code 


| Py cnaieat- 2 Unit Number RESERVED 


RESERVED 


Allocation Length ace 


Allocation Length (LSB) 


RESERVED 


6.17 SEND DIAGNOSTIC COMMAND 
PERIPHERAL DEVICE TYPE: ALL 
OPERATION CODE TYPE: OPTIONAL 
OPERATION CODE: 1DH 


Table 43: Send Diagnostic Command 


RESERVED |\SelfTest| RESERVED | UnitOfl § 
RESERVED 


Parameter List enaek (MSB) 


Parameter List Length (LSB) 


5 P ’ 
RESERVED | 
ort 53 peoerecnos Lae ata Pee ee SE. ge pie TR TOES ty I am aaa aren or eneraC an f PIM NTs PSII, ATS SANTONIO ITE STEN CIE SENET RT OY Tee . 


The Send Diagnostic Command requests that the Target perform self-diagnostic tests. There are no 
additional parameters for the user Send Diagnostic Command. 


The Unit-Off-Line (UNITOFL) is not used in the ST225N. 
The Self-Iest (SLFTST) bit, if one, directs the Target to complete its default self-test. lf this test is 


requested, the Parameter List Length must be set to zero. A Receive Diagnostic Results Command 
is required to receive self-test results. 
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If the SLFTST bit is not set, this command will always return with GOOD STATUS (no operation). 


Note: This command allows the operating system to be independent of vendor-unique diagnostic com- 
mands. The diagnostic software then becomes more portable to various operating systems. 


6.18 READ CAPACITY COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: Extended 
OPERATION CODE: 25H 


Table 44: Read Capacity Command 


BIT | 7 6 5 4 3 2 1 | 
BYTE | 


Operation Code 


] Logical Unit Number RESERVED RelAdr § 


Logical Block Address (MSB) 


Logical Block Address 
Logical Block Address 
Logical Block Address (LSB) 
RESERVED 


RESERVED 


RESERVED 


RESERVED Link | 


The Read Capacity Command provides a means for the Initiator to request information regarding 
the capacity of the drive. 


vu 
< 
a" 


The Partial Medium Indicator (PMI) bit, if zero, indicates that the information returned in the Read 
Capacity Data will be the Logical Block Address and Block Length of the last logical block of the 
drive. The Logical Block Address in the Command Descriptor Block must be set to zero for this option. 


The PMI bit, if one, indicates that the information returned will be the Logical Block Address and 


Block Length of the last logical block after the Logical Block Address specified in the Command Descrip- 
tor Block before a substantial delay in data transfer (e.g., a cylinder boundary). 
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Table 45: Read Capacity Data 7 


The following eight bytes of Read Capacity Data are sent during the data-in phase of the command. 


BYTE 


Block ieneth 


Block Length (LSB) 


6.19 READ COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: EXTENDED 
OPERATION CODE: 28} 


The Read Command requests that the Target transfer data to the Initiator. 

The Logical Block Address specifies the Logical Block where the Read operation shall begin. 

The transfer length specifies the number of contiguous blocks of data to be transferred. A transfer 
length of zero indicates that no logical blocks shall be transferred. This shall not be considered an 


error condition. Any other value indicates the number of logical blocks to be transferred. 


The most recently written data value will be returned. 
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Table 46: Read Command 


: 
—— 
| anes 


Transfer Length (MSB) 


Transfer Length (LSB) 


6.20 WRITE COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: EXTENDED 
OPERATION CODE: 2AH 


The Write Command requests that the Target write the data transferred by the Initiator to the medium. 
The Logical Block Address specifies the Logical Block where the Write operation shall begin. 
The Transfer Length specifies the number of contiguous blocks of data to be transferred. A Transfer 


Length of zero indicates that no logical blocks shall be transferred. This is not considered an error 
condition. Any other value indicates the number of logical blocks to be transferred. 
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Table 47: Write Command _ 


BYTE es | | a ee 


Operation Code 


1 | Logical Unit Number . RESERVED 


Logical Block Address (MSB) 


Logical Block Address 


Logical Block Address 


Logical Block Address (LSB) 


RESERVED 
Transfer Length (MSB) 


Transfer Length (LSB) 


RESERVED Link 


~N Wi > | W NO | i 


3 
| 
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6.21 READ DEFECT DATA COMMAND 
PERIPHERAL DEVICE TYPE: DIRECT ACCESS 
OPERATION CODE TYPE: EXTENDED 
OPERATION CODE: 37H 


Table 48: Read Defect Data Command 


BIT 
BYTE 


7 


; 
[ 
i 
c 
E 
E 
c 
hi 


Operation Code 


1 f Logical Unit Number RESERVED 
2 | RESERVED Ce. & | RESERVED 
‘ 


RESERVED 


RESERVED 


RESERVED 


RESERVED 


Allocation Length (MSB) 


Allocation Length (LSB) 


RESERVED Link 


Defect List Header 


RESERVED 


RESERVED poe | oc RESERVED 


Defect List Length (MSB) 


Defect List Length (LSB) 
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Velect Entry | | 
BIT 
peep TT TT 


ae cylinder (LSB) 
oe 


Defect Number 


Reassigned Entry 


Old Cylilnder (MSB) 


Old Cylinder (LSB) 
Old Head 
_ Defect Number (DEh) 


New Cylinder (MSB) 


New Cylinder (LSB) 


New Sector 


Fil 
Po 
oy 
Pe 
an 
pe | 
= 


Defect Number (och) 


ar 


The Read Defect Data command requests that the Target transfer medium defect data to the Initiator. 


The P-byte of byte-two requests that the Target return only the manufacturers defect list. The G-byte 
of byte-two requests that the Target return the host-added defects, as well as the reassigned block entries. 
This bit is only valid when the P-bit is set as well, allowing transfer of the entire defect management list. 


The allocation length specifies the number of bytes reserved for the returned defect data. An alloca- 
tion length of zero indicates no defect data is to be returned. Any other value indicates the maximum 
number of bytes that will be returned. The Target will determine the data-in phase when allocation 
length bytes have been transferred or all available defect data has been sent, whichever is less. 
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A maximum of 512 bytes can be papeaies by the drive. 

The Read Defect data contains a four-byte header, followed by peieet more defect descriptors. 
-Byte-one indicates the defect list actually returned by the Target. 

The Defect List length contains the actual length of the defect unadjusted for truncation. 

The defect data returned is in physical address format. 


The defect number (less than 100) identifies this as a defect entry and its number. The defect number 
field is also used to indicate a reassigned block pair of entries when it contains DEY. 


The Reassigned block entry contains the original (old) address followed by the reassigned address (new). 


The defect list is supplied sorted in ascending order using the old address for the reassigned blocks. 
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SENSE KEYS AND 
1 CODE DESCRIPTIONS 


Table 49: Sense Keys (0-7) 


Sense Key 
OH 


1H 


2H 


3H 


4H 


SH 


6H 


Description 
NO SENSE: Indicates that there is no specific Sense Key information to 
be reported for the designated unit. 


RECOVERY ERROR: Indicates that the last command was successfully 
completed, with some recovery action performed by the drive. Details can 
be determined by examining the Additional Sense bytes and the Informa- 
tion bytes. 


NOT READY: Indicates that the drive cannot be accessed. Operator inter- 
vention may be required to correct this condition. 


MEDIUM ERROR: Indicates that the command terminated with a non- 
recovered error condition which was probably caused by a flaw in the 
medium, or an error in the recorded data. 


HARDWARE ERROR: Indicates that the drive detected a nonrecovera- 
ble hardware failure (controller failure, device failure, etc.) while perform- 
ing the command, or during a self-test. 


ILLEGAL REQUEST: Indicates that there was an illegal parameter in the 
Command Descriptor Block or in the additional parameters supplied as 
data for some commands 


UNIT ATTENTION: Indicates that a reset has occurred since the last 
selection. 


DATA PROTECT: Not Supported 


Table 50: Sense Keys (8-F) 


Sense Key 


Description 

BLANK CHECK: Not Supported 
VENDOR UNIQUE: Reserved 

COPY ABORTED: Not Supported 
ABORTED COMMAND: Not Supported 
EQUAL: Not Supported 

VOLUME OVERFLOW: Not Supported 
MISCOMPARE: Not Supported 

This Sense key is reserved 
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7.1 ERROR CODES 


Table 51: Error Codes 


Error 02—Seek Error: This code is logged whenever a seek fails to position the Read/Write heads 
to the correct cylinder. This error is reported after an unsuccessful retry or when retry is disabled. 


Error 03—Write Fault: When a Write Fault is detected the controller will terminate the active com- 
mand and presents this error on the next command. 


Error 04—Drive Not Ready: This error indicates that the drive was not up-to-speed when the com- 
mand was issued. 


Error 05—Address Mark Not Found: This error is presented after two revolutions on a track with no 
address mark found. 


Error 10—ID Field ECC Error: This error indicates an ECC error in an ID field. This error is reported 
after an unsuccessful retry or when retry is disabled. 


Error 11—Uncorrectable Data Error: This error indicates an unrecoverable data error on a data field. 
This error is reported after an unsuccessful retry or when retry is disabled. 


Error 12—Data Address Mark Not Found: This error indicates that the data field address mark could 
not be read. This error is reported after an unsuccessful retry or when retry is disabled. 


Error 14—No Match On ID Field: This error can occur on any Read or Write data command if two 
Indexes have passed without a match on the ID field. Retry is performed by reading any ID field on 
the track, calculating the track number and comparing it to the expected track number. If it does com- 
pare, then the error is reported to the host. 

Error 18—Recoverable ID ECC Error: This code indicates a successful retry of an ID ECC error. 
Error 19—Recoverable Data Error: This code indicates retry or error correction was successful. 
Error 1A—Recoverable Data Address Mark: This code indicates a successful retry of a Data Address 
Mark Not Found error. 


Error 1B—Recoverable ID Field: This code indicates a successful retry to match on an address mark. 


Error 20—Invalid Command: This error indicates that the received command byte is illegal or not 
implemented. 


Error 24—Invalid Parameter: This error indicates that the Command Block contained invalid 
parameter(s) or nonzero reserved areas. 


Error 25—Invalid Logical Unit Number (LUN): This error indicates that the Command Block addressed 
an illegal LUN (nonzero). 


Error 29—Internal Controller Error: This error indicates that an internal diagnostic has failed. 


Error 2A—Defect Map Overflow: This error indicates that the total number of defective sectors to 
be formatted exceeds the table size. 
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Error 2B—Time Out On Reselection: This code indicates that following Target disconnection, three 
reselection attempts on the Initiator have failed. 


Error 2C—Overflow On Usage Counter: This error indicates that one of the usage counters overflowed 
on the previous command; normally disabled from Status. 


Error 2D—Initiator Detected Error: This error indicates that the current command received an Initiator- 
detected error message. 


Error 2F—Target Reset: This code indicates that the Target was reset prior to this command; accompa- 
nies Unit Attention. 
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Appendix 1: Data Transfer Timing 


READ DATA TRANSFER 


REQUEST 


ACKNOWLEDGE —— |) 


100nsec typ. 


225nsec max. 225nsec max. 


470nsec min.* 


870nsec max. 


*Minimum worst case timing assumes Acknowledge is asserted 7Onsec prior to 
internal clock (400nsec) 


WRITE DATA TRANSFER 


REQUEST = ————__—_—______, 


| 


ACKNOWLEDGE lf 


VALID DATA 


DATA 


1080nsec max. 


580nsec min.* | 125nsec typ. 


*Minimum worst case timing assumes Acknowledge is asserted 8Cnsec prior to internal 
Clock (400nsec).. — 
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HANDSHAKE 


“BUS SET DELAY” = Maximum time for a bus device to assert BSY and its Bus Device ID bit on the data bus after it detects Bus Free Phase. 


“BUS FREE DELAY” = Minimum time that a bus device shall wait from its detection of Bus Free Phase unti! its assertion of BSY. 


“BUS CLEAR DELAY” = Maximum time for a bus device to stop driving all bus signals after Bus Free Phase is detected or SEL is received from a bus device 
during Arbitration. 
“ARBITRATION DELAY” = Minimum time a bus device shail wait from asserting BSY for Arbitration until the data bus can be examined to see if Arbitration 


has been won. 


bw—ej “BUS SETTLE DELAY” = Time to wait for the Bus to settle after changing certain control signals. 


2 Deskew Deskew Delay 


Initiator Asserts BSY | 


| Target Asserts BSY \ Delays 


(Busy) 
oot 
: Systems with 
(Select) +C/D no arbitration | 
start here 
(Control/Data) + C/D 


(Input/Output) + 1/0 


host adapter will act as the 
“INITIATOR.” and an I/O device's 
control unit will act as the 
“TARGET.” 


The INITIATOR 
waits an Arbitration 


Clear Delay then it 
asserts the Data Bus 
with both the desired IN- 


REQ The INITIATOR 
drives data (7-0.P) to 
their desired values. 


at least one deskew delay plus a 
cable skew delay. then asserts 
REQ Data (7-0.P) shall remain 


lonly one byte of | 
Status Is 


| phase. 


The message 


| er l 
, | | ‘ = | ! ae 


becomes con- 
tinuously false 
tor a Bus Settle | 


Delay then ex- ITIATOR ID bit and the waits at least one valid unt! ACK Is true at the | transferred byte could in- Delay. 

amines the Data TARGET'S ID bit. After deskew delay plus a TARGET | dicate ‘Com- 

Bus. If a higher two deskew delays the cable skew delay and See handshake mand Com- | The following | 
priority Bus Device INIT:ATOR asserts SEL asserts ACK The IN- The INITIATOR shall read data lproeeduie under | | plete” (00) in- phase will be 

ID bit is true on the ITIATOR continues to (7-0.P) after REQ Is true. then Data in phase dicating an Arbitration 
Data Bus (DB7 ts ARBITRATION drive data (7-0,P). then asserts ACK | | | interrupt. Phase. 


the highest). the IN- 
ITIATOR loses Ar- 


SYSTEMS: in systems 
with the Arbitration 


asserts REQ 


When ACK becomes true at the 


| | Typical “REQ”/“ACK"” Handshake Cycle IN. write Peripheral Device | | | i | 
(Message) + MSG 
(Request} + REQ 
(Acknowledge) + ACK 
(Attention) + ATN 
(Reset) + RST 
(Data Bit) DB (7 0 P) Initiator ID & Target jem os 4 ’ MES | Ay : gee 
Last wFirst Data Last Data : | 7 
| | CMD Byte CMD Byte (Write Peripheral) (Write Peripheral) iF Status Byte | Message Byte | 
! Bus INITIATOR tries to INITIATOR gained con- | TARGET requests | TARGET requests data transfer on TARGET re- | TARGET re- | Bus is 
| Free gain control of the trol of the Bus and command bytes from the bus. | quests that quests IN- | releasec. 
bus. selects a TARGET. | the INITIATOR. | status be sent to ITIATOR to | 
the INITIATOR. analyze 
J | | | | message. | | LL 
‘a | 
- 
NOTE: f BUS FREE ARBITRATION SELECTION COMMAND DATA IN OR STATUS | | MESSAGE IN | BUS FREE =) 
PHASE PHASE PHASE | PHASE | OUT PHASE | PHASE PHASE | PHASE | 
Most significant bit | (ENDING (INTERRUPT) | 
DBI7 Pj a fionty 1B for | Sel and implementation of During this phase the | The TARGET asserts | DATA !IN PHASE: Read Peripheral | STATUS} | | TARGET 
(7) fui aie y BSY are this phase ts a 1/0 signal is deasserted C/D and deasserts !/O | TARGET re- deasserts BSY | 
| both false system option e Sete as phase | Le for ae the Data is to be sent from TARGET to TARGET re- | quests aes) to indicate that 
for at least rom the Reselection andshakes of this INITIATOR | quests thata byte(s) to be the bus is 
NOTE: | one Bus At least one Bus Phase. phase Status byte be | sent from available for | 
DP(P) Data parity (odd) | Settle Free Delay. but no | TARGET asserts !/O. deasserts sent to the TARGET to subsequent 
Parity is not valid during Delay. more than one Bus NON ARBITRATING The transfer is from C/D and MSG during the | INITIATOR | INITIATOR | users. | 
Arbitration Set Delay. after Bus SYSTEMS In systems INITIATOR to REQ/ACK handshake of this 
| Free Phase has with the Arbitration | TARGET. phase TARGET asserts TARGET TARGET 
The use of parity is a system | been detected. the Phase not implemented. | C/D and 1/0 and asserts C/D, i/O | | releases all | 
option. INITIATOR asserts after detecting the Bus | HANDSHAKE HANDSHAKE PROCEDURE: deasserts MSG and MSG dur- bus signals 
BSY and its own Free Phase. the iN- PROCEDURE: | during the hand- | _, ing the | within a Bus | 
NOTE: Bus Device ID bit ITIATOR waits a | The TARGET first drives data | shake of this | REQIACK hand- Clear Delay 
In a typical system, a computer's on the data bus. minimum of one Bus The TARGET asserts (7-0.P) to their desired values. waits | _ phase. shake(s) of this | after BSY 
! | 


| See handshake 


bitration and Phase implemented. the When REQ becomes TARGET. the TARGET may procedure 
releases BSY If no INITIATOR that won Ar- false at the INITIATOR change or release data (7-0.P) and under Data in 
higher priority Bus bitration has both BSY the INITIATOR may deassert REQ phase. 


Devide ID bit ts true 
on the Data Bus. 
the the INITIATOR 
wins Arbitration and 
asserts SEL 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 


and SEL asserted and 
changes the Data Bus 
after two Bus Settle 
Delays. The Data Bus ts 
then asserted with both 
the desired INITIATOR 
1D bit and the TAR- 
GET'S ID bit Two 
deskew delays later BSY 
is released 


IN ALL SYSTEMS The 
TARGET determines 
that it is selected when 
SEL and its Bus Device 
ID bit are true and BSY 
and |/O are false for at 
least a Bus Settle Delay 
The TARGET then 
asserts BSY within a 
Selection Azort Time 


Two deskew aelays after 
the INITIATOR detects 


QCV tr ca +t rataaeac 


| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 


change or release 
data (7-0,P) and 
deassert ACK 


The TARGET con- 
tinues requesting 
command bytes The 
number of bytes 
depends on the com. 
mand group code 
detected from the first 
command byte 
received 


After REQ 1s false. the INITIATOR | 
deasserts ACK After ACK Is false. 
the TARGET may continue the 
transfer by driving data (7-0.P) and | 
asserting REQ | 


DATA OUT PHASE: Wiite Peripheral 


Data 1s to be sent from INITIATOR 
to TARGET 


TARGET deasserts D/D. 1’O and 
MSG during the REQ/ACK hand- 
shake of this phase Refer to the 
handshake procedure of the Com. 


SAMPLE SCSI TIMING CHART 


(COMMANDS WITHOUT 
NIGCONNECT/RECONNECT\ 


| 
| 
mand Phase | 
| 
| 
| 


| 
| 
| | 
| 
| 
| 


@ Xipueddy 


1 1SOS 


Appendix 3: Flow Chart For 
Disconnect/Reconnect 


1) Initiator Selects Target with ATTN Asserted 


2) Target requests Message Out Transfer (Identify Message) 
e Message asserted, C/D asserted, I/O false 


e Request asserted 
(DB) Bit 7 set for Identify Message (Initiator) 
Bit 6 set for disconnect capability 
Bit 5-0 zero 


e Initiator acknowledge 


3) Target Requests Command Transfer 
e Message false, C/D asserted, I/O false 


e Request asserted Target will request 6 bytes, pause and analyze command code to determine 
if this is a 10-byte command, if so, 4 more bytes will be requested. 


4) Read, Write, Seek, Format Command 


5) Target disconnection (if Identify was sent with disconnect bit) 


e Disconnect Message 
In 


e Message asserted, C/D asserted, I/O asserted (no change) 
e DB set to 04H 


e Request asserted 
Initiator acknowledge 


e Disconnect from Bus 
e Release DB 
e Release Busy, Select 


e Clear message, I/O, L/D 
Target complete Seek or Format 


- Reconnection Example for Read Data 


6) Target arbitrates for Bus 
e Wait for Bus Free 
e Drive Target ID on DB 
e If winner, drive Select & Busy 
e If loser & Select, complete selection, give Busy Status and disconnect 
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7) Target Reselects Initiator 


Drive Initiator & Target ID bits on Bus 
Message false, I/O asserted, C/D false 
Release Busy 

Wait for Busy from Initiator 


Timeout 250msec, go to Bus Free & retry twice 
Abort Command -Error Code: Initiator reselection Timeout 2BY 


Target drives Busy out 
Target clears Select 
Target clears I/O, Message & C/D already false 


8) Target Issues Identify Message 


Message asserted, I/O asserted, C/D asserted 
DB set to 70H -Identify, LUN 0 
Request asserted-Initiator acknowledge 


9) Target Requests Data Transfer IN 


Message false, C/D false, I/O false 


Request asserted 
Data transferred from Target to Initiator 


10) Target Presents Ending Status 
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Status byte transfer I/O & C/D asserted 
Message In -Command complete, Message, I/O & C/D asserted 
Disconnect from Bus 


Byte: Eight bits 


Command Descriptor Block: The structure used to communicate requests from an Initiator to a Target. 
Connect: Occurs when an Initiator selects a Target to start an operation. 


Disconnect: Occurs when a Target releases control of the SCSI Bus, allowing it to go to the Bus Free 
phase. 


Initiator: An SCSI device (usually a host system) that requests an operation to be performed by another 
SCSI device. 


Intermediate Status: A status code sent from a Target to an Initiator upon completion of each com- 
mand in a set of linked-commands (except the last command in the set). 


Logical Unit: A physical or virtual device 
LSB: Least significant bit 

LUN: Logical unit number 

MSB: Most significant bit 

One: A true signal value 


Peripheral Device: A peripheral device that can be attached to an SCSI device (e.g., magnetic disc, 
printer, optical disc or magnetic tape). 


Reconnect: Occurs when a Target selects an Initiator to continue an operation after a disconnect. 


Reserved: The term used for bits, bytes, fields and code values that are set aside for future standardi- 
zation. 


SCSI Address: The octal representation of the unique address (0-7) assigned to an SCSI device. This 
address would normally be assigned and set in the SCSI device during system installation. 


SCSI ID: The bit-significant representation of the SCSI address referring to one of the signal lines 
DB(7-0). 


SCSI Device: A host computer adapter, peripheral controller or an intelligent peripheral that can be 
attached to the SCSI Bus. 


Signal Assertion: The act of driving a signal to the true state. 


Signal Negation: The act of driving a signal to the false state or allowing the cable termninators to 
bias the signal to the false state (by placing the driver in the high impedance condition). 


Signal Release: The act of allowing the cable terminators to bias the signal to the false state (by plac- 
ing the driver in the high impedance condition). 


Status: One byte of information sent from a Target to an Initiator upon completion of each command. 
Target: An SCSI device that performs an operation requested by an Initiator. 


XX: Numbers followed by a subscript captial H are hexadecimal values. All other numbers are decimal 
values. 


Zero: A false signal value. 
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Appendix 5: Implementation 


Seek Command: Nonextended Sense is intended for SASI compatibility only. The Extended Sense length 
of 27 should always be requested to insure that all nine usage counters will be received in the event 
of a overflow. . 


Individual error codes are intended primarily for diagnostic purposes. Host recovery actions should 
be derived from the Sense Keys. 


The physical address corresponding to a given logical block address is provided for Host verification 
of defect mapping only. Logical block addresses must be supplied when specifing new defects during 
Format. 


Format Command: The Format Command should always be preceded by a Mode Select Command 
to set up the parameters. Three format options are provided. 


1. Format with manufacturer’s defect list: The controller will use the original manufacturer’s defect 
list (bytes from the Index format) only to generate a new defect list table for the requested block 
size. This option is required when changing the formatted block size. 


2. Format with manufacturer’s defect list plus supplied defects: This option allows the host to add 
defects in the logical block format to the current defect table using the same blocksize. Defects 
must be supplied in ascending order. 

3. Format with known defect list only: This option allows the host to re-format the drive using the 
current defect table (manufacturer’s list plus any previously added defects) using the same block- 
size. This command would typically be used to preserve the defect table when changing the inter- 
leave factor, etc. 

Read Usage Counters: The usage counters provide diagnostics information since the last power on. 

To compile a usage history, the counters should be read before power-down and usage enabled (see 


Mode Select) to present an error warning upon overflow. 


Upon an overflow, the counters are saved and reported in Sense or by Read Usage Counters (whichever 
comes first). The counters are always cleared after reading. There are five counters. 


1. Blocks Read: The total number of data blocks transferred to the host. 


2. Seeks: The total number of seeks requiring repositioning including seek error recovery and cylinder 
switch during reads. 


3. Uncorrectable Read Errors: The total number of times that ECC was applied (including retries) 
without correction. 


4. Correctable Read Errors: The total number of times that ECC was applied with correction. - 


5. Seek Errors: The total number of times that a positioning seek failed to locate the correct track. 
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Mode Select: Primarily used to select a blocksize prior to format. Unspecified (zero) perameters wil! 
revert to the default values for the requested blocksize. The full disc capacity will always be formatted, 
but an artificial maximum number of blocks may be specified. 


1. The Usage, Recovery and Status bits allow host control of certain optional controller features. 


2. Usage will cause command rejection with overflow sense following overflow of any counter on the 
previous command. | 


3. Recovery allows the host to disable error recovery, including ECC and retries for diagnostic purposes. 


4. Status allows the host to enable error presentation which indicates if error recovery was used on 
the current command. 


Mode Sense: reports back all Mode Select parameters plus the physical parameters for the drive including 
the currently formatted interleave factor. 


Message Out: Transfers (Attention condition) are performed immediately following selection and dur- 
ing data transfers. Message Out during transfers implies immediate command termination. 
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